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ABSTRACT 

A  comparison  of  existing  placement  techniques  is  presented. 
Large  realistic  printed  circuit  board  problems  are  introduced  and  used  to 
make  comparisons.   The  value  of  different  placements  is  measured  by  the 
total  wire  length  generated  as  well  as  by  the  results  of  actually  routing 
the  connections  on  the  board. 

A  new  wire  routing  algorithm  called  Channel  Routing,  is  proposed. 
The  Channel  touting  algorithm  is  faster  than  existing  routing  techniques 
and  can  handle  very  large  circuit  board  problems.   The  results  of  imple- 
menting the  basic  Channel  Routing  algorithms  are  presented.   These  results 
are  also  used  to  compare  the  effectiveness  of  the  different  placement 
algorithms. 
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1.    INTRODUCTION 

Since  its  beginning  in  1955?  automated  design  of  digital 
electronic  equipment  has  become  a  formidable  area  of  study.   A  large  body 
of  information  has  been  published  in  the  open  literature  [  3] ,  including  a 
recently  published  book,  [ 11] ,  which  deals  solely  with  the  current  tech- 
niques for  the  automated  design  of  computer  hardware.   Design  automation 
has  been  incorporated  into  every  level  of  manufacturing,  from  register 
level  computer  descriptions  to  the  diagnostic  testing  of  the  finished 
product.   This  dissertation,  however,  is  restricted  to  the  problem  of 
automated  printed  circuit  board  design,  which  involves  the  placement  of 
components  on  the  board  and  the  routing  of  wires  to  interconnect  them. 

Optimal  solutions  to  the  placement  problem  can  be  found  only 
for  boards  containing  no  more  than  20  components  [5>6].   In  the  case  of 
wire  routing,  optimal  solutions  can  be  obtained  [20]  for  individual  wires 
but  not  for  an  entire  board.   Modern  printed  circuit  boards  present  large 
placement  and  wiring  problems  with  up  to  200  components  being  intercon- 
nected on  one  board.   Therefore,  hueristic  procedures  are  used  for  find- 
ing reasonable,  sub-optimal  placements  and  wire  routings  for  these  boards. 
Comparing  these  hueristic  procedures  to  determine  the  most  effective  tech- 
niques is  extremely  difficult,  and  to  date,  no  realistic  comparison  of 
published  algorithms  has  been  made.   Steinberg's  3^  component  problem  [  16] 
has  been  widely  used  for  comparing  placement  algorithms  [11,19],  but  it 
is  too  small  to  be  considered  realistic  today.   The  only  comparison  of 


wire  routing  algorithms  is  made  in  terms  of  the  computer  time  required 
to  route  similar  sized  problems.   One  primary  purpose  of  this  disserta- 
tion is  to  begin  a  realistic  comparison  of  hueristic  design  automation 
algorithms  by  publishing  some  large  printed  circuit  board  problems. 

ILLIAC  IV  is  a  large  parallel  processing  computer  designed  by 
the  University  of  Illinois  and  built  by  Burroughs  Corporation  [1,2].   A 
unique  situation  therefore  exists  in  which  a  public  institution  has  access 
to  the  detailed  design  specification  of  a  large  modern  computer.   Such 
information  is  usually  subject  to  industrial  proprietary  classification. 
Proper  application  of  this  information,  particularly  to  the  area  of 
design  automation  should  benefit  the  academic  community  as  well  as  in- 
dustry.  The  printed  circuit  board  design  problems  found  in  the  ILLIAC  IV 
control  unit  are  large,  obviously  realistic  problems.  Widespread  use  of 
these  design  specifications  as  test  problems  should  produce  significant 
new  information  about  the  placement  and  routing  of  printed  circuit  boards. 

Chapter  5  proposes  a  new  algorithm  [27]  for  wire  routing  which 
is  designed  for  interconnecting  integrated  circuit  packages.   The  new 
routing  algorithm  combines  the  best  properties  of  some  existing  tech- 
niques, reviewed  in  Section  5-1?  to  achieve  faster  speed  and  greater 
flexibility.   The  implementation  of  the  basic  algorithm  is  discussed  in 
detail  and  results  are  presented  for  the  wiring  of  ILLIAC  IV  sample  pro- 
blems.  The  wire  routing  program  is  also  used  to  compare  the  results 
from  various  placement  algorithms. 


2.   THE  ILLIAC  IV  DESIGN  PROBLEM 

The  Control  Unit  (CU)  of  the  ILLIAC  IV  computer  is  composed  of 
many  large  multilayer  printed  circuit  hoards.   Each  hoard  can  contain  up 
to  l65  integrated  circuit  packages  arranged  in  eleven  rows  of  fifteen 
packages  each  (Fig.  l).   The  integrated  circuit  packages  employed  are 
sixteen  pins  dual  inline  packages.   The  integrated  circuits  use  high 
speed  emitter  coupled  logic  (ECL)  technology  with  gate  times  in  the  range 
of  two  to  four  nanoseconds. 

The  placement  and  wiring  of  the  ILLIAC  IV  CU  hoards  represents 
a  large  collection  of  design  automation  problems.   This  set  of  problems 
was  first  solved  hy  the  Burroughs  Corporation  along  with  the  University 
of  Illinois.   The  high  speed  which  was  sought  for  the  ILLIAC  IV  CU  dictated 
a  number  of  very  strict  wiring  rules.   First  of  all,  a  multilayer  board 
was  required  so  that  ground  planes  would  surround  each  signal  layer  in 
order  to  insure  proper  transmission  line  effects.   The  use  of  transmission 
line  technology  also  restricted  the  manner  in  which  connections  could  be 
made.   Each  connection  was  required  to  proceed  from  the  source  through 
each  load  until  the  final  one  where  it  was  to  be  terminated  by  the  proper 
resistance.   Each  pin  to  be  connected  could  have  only  two  wires  connected 
to  it  so  the  connection  had  to  be  chained  (Fig.  2).   In  addition,  there 
was  a  minimum  limit  placed  on  the  length  of  each  connection  in  order  to 
eliminate  unwanted  reflections.   In  certain  special  cases  further  res- 
trictions were  imposed.   For  the  sake  of  timing  the  lengths  of  two  wires 
were  sometimes  required  to  be  identical  which  resulted  in  laying  out 
portions  of  some  boards  completely  by  hand. 
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Figure  1.   ILLIAC  IV  CU  Board 
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Figure  2.   A  Chained  Connection. 


For  the  purposes  of  this  dissertation  the  CU  board  design 
problem  will  be  somewhat  simplified.   What  is  desired  is  a  set  of  large 
realistic  design  problems  which  are  to  be  solved  using  a  set  of  widely 
known  and  accepted  wiring  rules.   The  first  step  in  simplifying  the  design 
problem  is  to  consider  only  the  signal  connections  to  be  made  on  each 
board.   The  specification  of  the  wiring  for  each  board  is  presented  in  the 
form  of  a  netlist .   By  removing  the  power  and  ground  connections  from  each 
netlist,  specifications  can  be  presented  which  determine  only  the  signal 
connections  to  be  made.   Simplified  netlists  for  five  CU  boards  are  listed 
in  Appendix  A.   A  second  step  in  simplifying  the  design  problems  is  to 


specify  a  less  restrictive  set  of  wiring  rules.   The  following  set  of 
rules  was  chosen  to  provide  the  greatest  ease  in  comparing  different  place- 
ment and  routing  techniques: 

1.  No  upper  or  lower  limit  is  imposed  on  the  length  of  any 
one  connection. 

2.  No  limit  exists  on  the  distance  that  two  adjacent  wires 
may  run  in  parallel. 

3.  All  wire  segments  are  vertical  or  horizontal.   (Manhattan 
geometry. ) 

k.      No  limit  is  placed  on  the  number  of  wires  which  can  meet  at 
one  point. 

5.  A  two-sided  "board  can  be  used  for  wiring. 

6.  Potential  positions  for  packages  as  well  as  positions  of 
edge  connectors  are  fixed  on  the  board. 

7-   Plated  through  communicating  holes  (Vias)  can  be  specified 
by  the  design  process  and  are  not  limited  in  number. 
Such  a  simplified  set  of  wiring  rules  is  intended  only  to  help  in  compar- 
ing the  effectiveness  and  speed  of  a  wide  range  of  placement  and  routing 
algorithms.   In  order  to  be  useful,  design  algorithms  should  be  capable 
of  handling  more  difficult  problems. 

The  detailed  specification  of  the  CU  board  has  also  been  sim- 
plified somewhat.   The  positions  reserved  for  pulldown  and  terminating 
registers  have  been  eliminated  and  the  position  of  edge  connectors  has 
been  slightly  rearranged.   The  results  of  this  dissertation  are  based  on 
the  following  specifications: 


1.  Eleven  rows  of  fifteen  package  positions  (Fig.  l). 

2.  Package  pins  numbered  from  lower  left  in  a  counterclock- 
wise fashion  (Fig.  3)« 

3.  Minimum  wire  spacing  is  50  mils. 

h.      Packages  are  .75  inches  apart  in  the  vertical  direction 

and  .5  inches  apart  horizontally.   (Fig.  h.)      (The  package 
spacing  is  retained  from  the  original  specification  as  an 
arbitrary  reference.) 
5.   Edge  connectors  are  arranged  in  fifteen  groups  of  sixteen 
pins  each.   Each  group  is  directly  below  a  column  of 
packages  and  the  pins  are  numbered  as  shown  in  Figure  5- 
(Note  that  each  group  of  edge  pins  can  be  treated  as  a 
t     package  position  for  the  purposes  of  placement  and  wiring. , 
Once  again  the  aim  of  this  simplified  specification  is  to  make  the  CU 
board  design  problems  easy  to  work  with  so  that  comparison  of  different 
algorithms  can  be  facilitated. 
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Figure   3«      An  Integrated  Circuit  Package 
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Figure  h.      Package  Spacing. 
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Figure  5-   An  Edge  Connector  Group. 
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3.    GENERAL  DESIGN  AUTOMATION  DISCUSSION 

3*1  Measurement  Techniques 

The  overall  objective  of  a  design  automation  system  is  to 
manufacture  a  piece  of  equipment  with  a  given  performance  in  the  short- 
est possible  time  and  for  the  lowest  possible  cost.   Since  decreasing 
the  production  time  usually  requires  an  increase  in  cost,  some  tradeoff 
must  be  made  between  these  goals.   The  objective  of  each  stage  of  the 
design  process  is  also  some  minimization  of  time  and  cost.   For  the 
functions  of  placing  and  wiring  printed  circuit  boards  the  amount  of 
time  can  usually  be  measured  directly,  whereas  the  costs  involved  are 
quite  complex.   In  order  to  minimize  production  costs  it  has  been  tra- 
ditionally assumed  that  placement  algorithms  should  strive  toward  mini- 
mizing the  total  wire  length  and  the  routing  algorithm  should  strive 
toward  minimizing  the  amount  of  area  consumed  in  wiring.   These  mea- 
surements will  be  used  throughout  this  paper  to  compare  the  effective- 
ness of  various  techniques.   However,  consideration  will  be  given  to 
the  possibility  of  determining  more  meaningful  measurements. 

In  order  to  minimize  costs,  a  placement  algorithm  should  pro- 
duce a  placement  which  can  be  wired  efficiently  under  a  given  set  of 
wiring  rules.   The  ease  of  routing  a  board  is  typically  dependent  on  the 
number  of  crossovers  and  the  amount  of  congestion  in  a  given  area  as  well 
as  on  the  total  amount  of  wire  that  must  be  routed.   It  is  generally 
assumed  that  decreasing  the  total  wire  length  will  decrease  the  number 
of  crossovers  and  the  amount  of  congestion  in  specific  areas.   This  may 
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be  true,  but  at  the  same  time  it  is  obvious  that  there  are  other  ways  of 
more  directly  improving  the  wireability  of  a  board  which,  for  instance, 
might  take  into  account  the  amount  of  congestion  in  a  given  area.   In 
Chapter  k   of  this  dissertation  there  is  a  quantitative  evaluation  of  the 
factors  contributing  to  the  wireability  of  a  board. 

3-2  The  Assignment  Problem 

The  simple  assignment  problem  can  be  demonstrated  in  terms  of 
assigning  modules  to  positions,  where  a  specific  cost  can  be  determined 
for  the  assignment  of  a  particular  module  to  a  particular  position  inde- 
pendent of  the  positions  of  other  modules.   If  the  objective  is  to  mini- 
mize the  cost,  this  can  be  accomplished  by  minimizing  the  sum  of  all 
individual  costs,  C. .,  of  assigning  module  i  to  position  j  ,  where  each 

-'-J 

module  can  be  assigned  to  one  and  only  one  position.   Munkres  [  k]   has 
formulated  a  solution  to  this  problem  which  is  practical  for  up  to  200 
modules. 

Placing  a  package  on  a  printed  circuit  board,  however,  does  not 
have  a  fixed  cost  (in  wire-length)  that  is  independent  of  the  position  of 
other  packages.   The  placement  problem  cannot  therefore  be  formalized  as 
a  simple  assignment  problem.   The  placement  problem  can  be  formalized  as 
a  quadratic  assignment  problem,  but  there  are  no  known  solutions  to  the 
quadratic  assignment  problem  that  are  practical.   The  most  obvious 
solution  is  to  simply  enumerate  all  possible  assignments  and  determine 
which  has  the  lowest  cost  (total  wire-length).   Such  a  solution  requires 
n.'  assignments  and  cost  evaluations  and  could  be  used  only  for  the  smallest 
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problems.   Branch  and  bound  techniques  reduce  the  number  of  operations 
required  and  can  be  used  for  small  n  (15  -  20)  as  shown  by  Lawler  [5] 
and  Gilmore  [6].   The  computation  time  for  these  techniques  increases 
exponentially  as  the  number  of  packages  increases. 

As  a  result,  the  placement  problem  for  large  printed  circuit 
boards  has  been  approached  by  heuristic  algorithms.   Measurement  of  the 
comparative  effectiveness  of  heuristic  techniques  is  very  difficult  since 
optimum  solution  are  usually  unknown  and  since  large  realistic  problems 
are  not  publicly  available.   Therefore,  the  thrust  of  the  placement  por- 
tion of  this  dissertation  is  the  comparison  of  existing  heuristic  algo- 
rithms. 

3.3  The  Interconnection  Problem 

When  several  points  on  a  printed  circuit  board  are  to  be  made 
electrically  common,  the  interconnection  which  connects  them  is  called  a 
net.   The  manner  in  which  a  net  is  formed  is  often  determined  by  the 
wiring  rules  of  the  board.   The  wiring  rules  adopted  in  Chapter  2  do  not 
place  any  restrictions  on  the  manner  in  which  nets  can  be  connected.   Each 
net  is  therefore  connected  in  such  a  way  as  to  minimize  the  amount  of  wire 
used.   The  minimum  spanning  tree  algorithm  of  Prim  [7]  is  used  to  determine 
how  each  net  is  connected.   This  algorithm  assumes  that  each  connection 
must  be  made  from  one  node  on  the  net  to  another  node  on  the  net  (Fig.  6a). 
If  additional  nodes  are  allowed  to  be  added  the  result  is  a  Steiner  [9] 
tree  which  will  always  have  a  wire  length  less  than  or  equal  to  that  of 
the  minimum  spanning  tree  (Fig.  6b).   However,  Steiner  trees  are  much  more 
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difficult  to  find  than  minimum  spanning  trees  [  10]  and  they  place 
considerable  restrictions  on  the  actual  wire  routing.   Also,  when 
Manhattan  geometry  is  used,  the  difference  between  the  wire  length  of  a 
Steiner  tree  and  that  of  the  corresponding  minimum  spanning  tree  tends  to 
he  very  small. 
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Figure  6.        Minimum  Spanning  Tree  Versus   Steiner  Tree. 
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k.      PLACEMENT 

k. 1  Preliminaries 

h . 1 . 1  Connection  Specification 

In  order  to  generate  a  placement  it  is  necessary  to  obtain  a 
complete  specification  of  the  interconnections  to  be  made  between  com- 
ponents.  This  specification  usually  takes  the  form  of  a  list  of  signal 
nets.   The  elements  in  this  list  contain  the  name  of  the  component,  the 
pin  on  that  component  to  be  connected,  a  source/load  indication  and  the 
name  of  the  signal  net.  When  the  list  follows  the  format  of  each  source 
being  immediately  followed  by  all  of  its  loads  the  signal  name  is  not 
needed  to  determine  which  nodes  (list  elements)  are  on  the  same  net.   This 
format  will  be  used  for  specifying  the  signal  nets  for  the  ILLIAC  IV  CU 
boards  ( see  Appendix  A) . 

To  facilitate  the  use  of  interconnection  information  a  program 
was  written  to  read  the  net  list  and  generate  cross  reference  tables  con- 
taining all  the  needed  information.   All  of  the  placement  programs  re- 
ferred to  in  this  paper  work  directly  from  these  tables.   The  first  table, 
COMPS,  contains  one  entry  for  each  pin  of  each  component  to  be  placed  on 
the  board.   This  table  is  stored  as  an  array  with  one  dimension  being  the 
component  number  and  the  other  being  the  pin  number  on  that  component. 
Each  entry  in  this  table  has  one  of  four  meanings,  depending  on  its  initial 
character. 
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1.  The  component  and  pin  number  to  which  this  pin  connects. 
Component  names  begin  -with  an  "A". 

2.  The  edge  connector  pin  of  the  board  to  which  this  connects. 
Edge  connector  pin  names  begin  with  a  "P". 

3-   The  number  of  the  net  to  which  this  pin  connects. 

Net  numbers  begin  with  a  blank. 
h.      No  connection  is  made  to  this  pin. 

No  connection  is  indicated  by  a  "*". 

U.1.2  Wire  Length  for  One  Package 

Often  times  during  the  course  of  a  placement  algorithm  it  is 
useful  to  know  the  contribution  made  to  the  total  wire  length  by  the 
connections  from  only  one  package.   Such  information  allows  a  computer 
program  to  determine  whether  moving  one  component  to  a  new  position  will 
increase  or  decrease  the  total  wire  length.   When  such  a  component  is 
connected  to  one  or  more  nets  it  is  very  difficult  to  determine  exactly 
how  much  wire  is  contributed  by  that  component.   The  only  way  to  find  out 
how  much  wire  is  used  is  to  measure  the  entire  wire  length  of  the  net  with 
the  component  being  moved  first  in  one  position  and  then  in  the  other. 
This  measurement  gives  the  change  in  the  wire  length  of  the  net  due  to  the 
moving  of  one  component  but  it  does  not  tell  how  much  wire  that  component 
adds  to  the  net  in  each  position.   The  contribution  made  to  the  total  wire 
length  by  the  connections  from  only  one  package  will  not  be  measured.   In 
each  case  the  total  wire  length  of  the  connections  from  one  package  will 
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be  measured  including  the  entire  length  of  each  net.   Whereas  such  a 
measurement  is  not  useful  in  itself,  the  difference  in  two  of  these 
measurements  gives  the  exact  change  in  the  total  wire  length  that  results 
from  moving  one  component  to  a  new  position. 

h.2.     Serial  Placement  Techniques 
J+.2.1  General  Description 

Serial  placement  algorithms  assign  packages  to  positions  on  a 
printed  circuit  board  in  only  one  pass.   One  package  at  a  time  is  chosen 
and  placed  in  a  final  positions,  until  all  of  the  packages  have  been  placed. 
"his  process  can  be  broken  down  into  two  distinct  subprocesses.   The  first 
is  the  selection  process  which  chooses  the  next  package  to  be  placed  and 
the  second  is  the  positioning  process  which  assigns  the  chosen  package  to 
a  position  on  the  board.   These  two  subprocesses  are  quite  independent  and 
several  methods  have  been  described  for  performing  each  of  them  [11].   The 
obvious  advantage  of  using  a  serial  placement  algorithm  is  the  speed  of 
execution,  with  the  number  of  operations  performed  being  directly  proport- 
ional to  the  number  of  units  being  placed.   The  obvious  disadvantage  of 
the  serial  techniques  is  that  once  a  unit  is  placed,  it  can  not  be  moved 
to  compensate  for  further  developments.   Because  of  this  rigidity  in  the 
serial  methods,  along  with  their  speed,  they  are  often  used  simply  to 
generate  initial  placements  for  other  placement  algorithms. 

The  order  in  which  units  are  to  be  placed  is  determined  by 
maximizing  some  objective  function.   This  function  is  dependent  on  the 
number  of  connections  that  each  package  has.   One  of  the  simplest  such 
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functions  is  the  pair  linking  method  [  ll|]  which  proceeds  in  the  following 
manner.   At  any  given  time  in  the  serial  placement  process,  some  packages 
have  been  placed  on  the  board  and  some  are  available  to  be  placed  ^Fig.  7). 
The  pair  linking  method  finds  the  package  not  already  placed  which  has  the 
greatest  number  of  connections  to  one  package  which  has  been  placed.   Thus, 
the  most  strongly  linked  pair  between  the  unplaced  and  placed  packages  has 
been  found  and  the  unplaced  member  of  the  pair  is  assigned  to  be  the  next 
package  placed.   At  this  time  the  selected  package  can  be  assigned  to  a 
final  position  on  the  board  or  it  can  simply  be  entered  into  the  set  of 
placed  packages  so  that  the  entire  order  of  placement  can  be  determined. 
The  process  can  be  broken  into  two  separate  routines,  the  first  one  orders 
the  packages  and  the  second  one  positions  them  on  the  board.   Different 
ordering  and  positioning  algorithms  can  then  be  intermixed  conveniently. 
The  cluster  development  [  lU]  selection  method  uses  a  more  com- 
plex objective  function  than  the  pair  linking  method.   In  cluster  devel- 
opment, the  next  package  to  be  placed  is  the  one  among  the  unplaced  pack- 
ages which  has  the  greatest  number  of  connections  to  already  placed  pack- 
ages.  Counting  the  number  of  connections  to  other  units  presents  a  slight 
problem  for  both  the  cluster  development  method  and  the  pair  linking 
method.   The  problem  is  to  determine  how  many  wires  are  needed  to  connect 
a  package  to  a  net.   In  Figure  6a,  nodes  A,  B,  C,  D  and  E  are  all  con- 
nected on  one  net.   Whereas  nodes,  A,  C  and  E  are  connected  to  the  net  by 
only  one  wire,  node  D  is  connected  by  two  wires  and  node  B  is  connected 
by  three  wires.   At  the  time  that  one  package  is  being  placed,  some  of 
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NOT  PLACED 


Figure  "J.      Package  Selection. 


the  packages  which  are  connected  to  it  "by  nets  may  not  be  placed  so  that 
complete  formation  of  the  net  is  impossible.   One  solution  to  this  pro- 
blem is  to  form  as  much  of  the  net  as  possible,  for  instance,  to  create  a 
minimum  spanning  tree  for  the  nodes  which  correspond  to  the  already  placed 
packages  of  the  net.   This  approach  will  not  be  perfectly  accurate  so  a 
less  time  consuming  approximation  should  be  acceptable.   Such  an  alter- 
native is  to  connect  the  package  being  placed  only  to  the  nearest  node  of 
the  net  in  each  case. 

The  motivation  behind  cluster  development  is  to  choose  the 
package  with  the  greatest  number  of  connections  to  packages  already  fixed 
in  position  so  that  the  chosen  package  can  be  placed  with  the  greatest 
accuracy.   A  further  criterion  for  choosing  a  package  might  be  to  minimize 
the  number  of  new  connections  to  unplaced  units  which  it  generates  [15]- 


19 


The  idea  here  is  to  create  the  fewest  possible  restrictions  on  the  future 
placement  of  packages.   The  realization  of  this  idea  is  to  choose  the 
package  which  has  the  greatest  difference  between  connections  to  already 
placed  packages  and  connections  to  unplaced  packages. 

The  second  half  of  each  serial  placement  algorithm  is  a  routine 
which  assigns  each  package  to  a  final  position  on  the  board.   The  objective 
in  placing  each  unit  is  to  minimize  the  amount  of  wire  that  is  added  when 
connecting  that  unit.   Only  those  wires  which  connect  to  already  placed 
components  may  be  considered.   The  most  obvious  and  also  the  most  time- 
consuming  method  for  finding  the  best  position  for  one  package  is  to  try 
it  in  every  available  position.   The  amount  of  wire  used  to  connect  the 
package  at  each  position  is  measured,  and  the  position  which  requires  the 
lowest  amount  of  wire  is  chosen  as  the  final  position.   In  order  to  de- 
crease the  amount  of  time  involved  several  simplifications  can  be  made. 

Rather  than  trying  each  unit  in  every  available  position  a  sub- 
set consisting  of  the  most  likely  positions  can  be  tried.   Since  the  edge 
connectors  on  an  ILLIAC  IV  CU  board  are  all  on  one  edge  (Fig.  1),  the 
placement  of  packages  will  begin  at  that  edge  and  grow  away  from  it.   In 
this  case  a  subset  consisting  of  the  first  available  position  in  each 
column  of  package  positions  (open  boxes  in  Fig.  8)  could  be  used.   This 
selection  limits  the  number  of  positions  tried  for  each  package  to  fifteen. 
A  much  more  flexible  set  of  candidates  can  be  conveniently  generated  in- 
volving a  slightly  larger  subset.   This  larger  subset  is  made  up  of  the 
positions  which  "outline"  the  previously  placed  packages  (all  boxes  in 
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Fig.  8).   Although  it  can  be  shown  that  the  optimum  position  for  a  pack- 
age may  not  be  contained  in  the  "outline,"  this  method  is  much  faster 
than  trying  all  available  positions. 


Figure  8.   Candidate  Positions , 
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h.2.,2.     The  Serial  Placement  Program 

One  serial  method  was  programmed  and  used  to  produce  placements 
which  could  be  compared  to  those  generated  by  other  techniques.  The  se- 
lection and  positioning  rules  employed  in  the  program  were  chosen  mainly 
for  their  ease  of  implementation  and  speed  of  execution.  No  attempt  was 
made  to  find  the  "best"  serial  placement  method.  The  intention  here  was 
to  implement  a  reasonable  technique  to  be  used  as  the  basis  for  some  mean- 
ingful comparisons.  The  placement  method  which  is  described  in  detail 
below,  will  be  referred  to  simply  as  the  Serial  Placement  method  for  the 
remainder  of  this  dissertation. 

The  selection  rule  employed  chooses  the  package  with  the  great- 
est number  of  connections  to  the  already  placed  packages.  Initially,  the 
only  packages  placed  on  the  board  are  the  edge  connectors  which  interface 
with  the  backplane.  Therefore,  the  first  package  chosen  for  placement  is 
the  one  which  has  the  greatest  number  of  connections  to  connector  pins. 
Implementing  such  a  scheme  is  quite  straightforward. 

Step  1.    Initialize  c..   Each  package  is  assigned  a  value  c.  which 

indicates  how  many  connections  it  has  to  connector  pins. 
Step  2.    Select  one  package  for  positioning.   Find  the  maximum  c.  and 

select  the  corresponding  package. 
Step  3.    Update  c.   For  each  package  connected  to  the  most  recently 

selected  package  c.  =  c.  +  n  where  n  is  the  number  of  times 

it  is  connected. 
Step  h.        If  all  packages  have  not  been  selected  yet,  return  to  Step  2. 
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In  the  algorithm  above,  Step  3  is  very  important.   The  most 
recently  chosen  package  may  be  connected  to  a  net  (a  connection  involving 
more  than  two  packages).  When  this  occurs,  each  package  on  the  net  will 
have  its  c  value  increased  by  one.   Each  package  on  a  net  is  therefore  con- 
sidered to  be  directly  connected  to  every  other  package  on  that  net  rather 
than  just  being  connected  to  the  net. 

Each  time  a  new  package  is  indicated  as  the  next  to  be  placed 
it  is  tried  in  several  of  the  available  positions  to  determine  which  one 
will  require  the  least  amount  of  wire  to  connect  it.   In  order  to  save 

time,  the  new  package  is  not  experimentally  connected  at  every  available 
board  position.   Only  those  positions  adjacent  to  already  placed  packages 
or  to  board  connector  pins  are  investigated  as  depicted  in  Figure  8.   The 
measurement  which  is  made  at  each  position  is  simply  the  Manhattan  dis- 
tance for  each  point-to-point  connection  plus  the  distance  to  the  nearest 
node  of  a  net.   In  many  cases  the  package  to  which  a  connection  should  be 
made  has  not  yet  been  placed.   In  such  instances  the  connection  is  com- 
pletely ignored,  and  for  this  reason  the  proper  formation  of  nets  could 
not  be  employed,  so  the  above  simplification  was  used. 

U.2-3  Serial  Placement  Results 

The  Serial  Placement  program  was  used  to  place  20  different 
ILLIAC  IV  CU  boards  (Table  l) .   These  20  boards  constitute  a  representat- 
ive subset  of  the  entire  set  of  6h   different  CU  boards.   This  subset  was 
chosen  on  the  basis  of  total  wire  length  and  number  of  packages.   The  pro- 
gram was  run  on  a  Burroughs  6500  computer  which  has  a  five  megahertz  basic 


Table  1.   Serial  Placement  Results 
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Board  Name 

Number  of 

Total  Wire 

Placement 

Vertical 

Horizontal 

Packages 

Length 

Time  (sec) 

Overflow 

Overflow 

FIRDB 

52 

725 

19 

0 

1 

FDS 

63 

1102 

18 

0 

0 

IWSCTL 

83 

1159 

2h 

0 

0 

FDQA 

93 

1230 

25 

0 

0 

FIRCB 

102 

1292 

27 

0 

0 

FORC 

96 

1313 

28 

0 

0 

IIAA 

118 

13^0 

^ 

0 

0 

FWLDF 

102 

13^6 

22 

0 

0 

ATP07 

101 

1U29 

27 

0 

k 

MTMCTL 

11U 

1U60 

25 

0 

0 

MPCTL 

99 

1527 

29 

0 

0 

TXFER 

97 

1608 

22 

0 

5 

ICTLA 

110 

1637 

26 

0 

0 

MDSPLY 

75 

1736 

20 

16 

32 

ATP05 

112 

1851 

k6 

^3 

0 

FBUSY 

119 

2058 

28 

2k 

3 

ATP25 

13U 

2126 

kl 

0 

0 

TCRFLD 

136 

2318 

30 

16 

9 

ILTCL 

li+1 

2U16 

37 

37 

0 

IICR1 

121 

3306 

38 

k2 

78 

2k 


clock  speed.   The  placement  times  shown  in  Table  1  give  the  processor 
time  used.   The  Channel  Routing  program  described  in  Chapter  5  was  used 
to  route  the  boards  placed  by  the  Serial  Placement  Program.   The  routing 
results  are  intended  to  measure  the  wireability  of  the  placements  and  to 
determine  whether  wire  length  measurement  can  be  used  to  predict  wire- 
ability. 

The  last  two  columns  of  Table  1  indicate  the  success  of  wiring 
the  boards  when  the  original  package  spacing  for  ILLIAC  IV  is  used.   This 
spacing  shown  in  Figure  k   allows  a  total  of  19  channels  for  each  package 
row  and  16  channels  for  each  column.   The  edge  connector  pins  are  located 
1-7  inches  from  the  first  row  of  packages  allowing  33  horizontal  channels 
in  that  area.   The  number  of  overflows  in  Table  1  is  the  number  of  addi- 
tional channels  needed  after  final  positioning  to  completely  wire  the 
board.   In  Table  2  additional  routing  information  is  given.   The  last  two 
columns  of  Table  2  indicate  the  minimum  number  of  channels  which  must  be 
available  in  each  row  or  column  of  packages  for  complete  wiring  using  the 
Channel  Router.   The  wireability  measure  is  intended  to  indicate  the  total 
amount  of  successful  wiring  as  well  as  the  distribution  of  wiring  density 
over  the  board. 

Table  3  is  the  correlation  matrix  of  several  of  the  variables 
present  in  Tables  1  and  2.   All  of  these  variables  are  shown  to  be  related 
by  the  fact  that  all  correlations  are  positive  with  most  of  them  above  .5. 
A  few  of  these  results  are  considered  significant.   The  high  correlation 
(.88)  between  the  number  of  connector  pins  used  and  the  number  of  vertical 
channels  required  may  be  helpful  in  partitioning  logic  onto  boards.   Such 
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Table  2.   Wire  Routing  of  Serial  Placements 


Board 
Name 

Connector 
Pins  Used 

Total  No.  of   Total  No.  of 
Vertical       Horizontal 
Channels       Channels 

Vertical 
Wirea'bility 

Horizontal 
Wirea'bility 

FIRDB 

57 

121 

116 

13 

20 

FDS 

156 

201 

112 

16 

18 

IWSCTL 

173 

181 

128 

15 

17 

FDQA 

91 

171 

li+8 

13 

17 

FIRCB 

ik6 

185 

1U2 

13 

15 

FORC 

Qk 

172 

Ike 

16 

18 

ITAA 

90 

163 

169 

15 

17 

FWLDF 

1U9 

187 

131 

Ik 

15 

ATP07 

156 

207 

137 

15 

21 

MTMCTL 

135 

176 

137 

lU 

15 

MPCTL 

15^ 

195 

158 

16 

18 

TXFER 

22U 

222 

ll+5 

16 

21 

ICTLA 

176 

221 

165 

16 

18 

MDSPLY 

223 

257 

15^ 

20 

26 

ATP05 

178 

250 

21U 

30 

19 

FBUSY 

220 

265 

181+ 

18 

21 

ATP25 

170 

232 

215 

16 

18 

TCRFLD 

196 

230 

205 

19 

22 

ILTCL 

211 

278 

192 

22 

18 

IICR1 

221 

283 

303 

21 

32 

26 


Table  3-   Correlations 


1            2 

3 

1+ 

5 

6 

7 

1.00      .1+0 

•  73 

.56 

.67 

.36 

.01+ 

.i+o  i.oo 

.69 

.88 

.1+8 

.53 

.50 

.73    .69 

1.00 

.86 

•  93 

•  59 

.66 

1.  Number  of  Packages 

2.  Connector  Pins  Used 
3-   Total  Wire  Length 
1+.   Total  No.  of  Vertical 

Channels  .56   .88   .86   1.00   .71   .72    .89 

5.  Total  No.  of  Horizontal 

Channels  .67   .1+8   .93   .71  1.00   .62    .61+ 

6.  Vertical  Wireability         .36   .53   -59   -72   .62  1.00    .1+2 

7.  Horizontal  Wireability        .0k     .50   .66        .89   .61+   .1+2   1.00 
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a  measure  should  help  predict  the  difficulty  of  wiring  the  boards  in  a 
given  partition.   The  total  wire  length  correlates  highly  with  the  number 
of  vertical  (.86)  and  horizontal  (.93)  channels  required.   However,  total 
wire  length  does  not  predict  wireability  consistently. 

U. 3   Iterative  Placement  Techniques 
h.3-1     General  Description 

All  iterative  placement  techniques  begin  with  a  complete  place- 
ment of  a  board.   These  initial  placements  can  be  generated  manually  or  by 
random  selection  or  by  another  placement  algorithm.   Each  step  in  the 
iterative  technique  changes  the  positions  of  a  subset  of  the  packages  so 
that  the  total  wire  length  of  the  board  is  decreased.   Thus,  after  any 
iteration,  the  board  is  completely  placed  and  the  process  may  be  termin- 
ated.  The  algorithm  continues  until  some  stopping  criterion  is  met.   Most 
times  these  methods  are  stopped  when  no  further  decrease  in  the  wire  length 
is  being  made.   The  advantage  of  iterative  schemes  is  that  they  produce 
better  placements  than  the  serial  methods.   Even  though  some  iterative 
techniques  are  very  simple  to  program  they  all  tend  to  require  large 
amounts  of  processing  time. 

An  exhaustive  pairwise  interchange  is  the  simplest  iterative 
scheme.   Each  iteration  consists  of  interchanging  two  packages  on  the 
board  and  determining  whether  that  interchange  results  in  a  decrease  in 
the  total  wire  length.   If  no  change  occurs  or  if  the  total  wire  length  is 
increased,  the  packages  are  returned  to  their  previous  positions.   An 
exhaustive  pairwise  interchange  systematically  attempts  every  possible 
interchange  between  two  packages  on  the  board.   The  exhaustive  pairwise 
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interchange  can  be  repeated  until  none  of  the  interchanges  result  in  a 
decrease  in  the  total  wire  length.   A  local  minimum  has  then  been  reached. 
An  exhaustive  three-way  interchange  is  a  similar  technique  which  tries  all 
possible  interchanges  of  three  units  in  each  iteration.   It  has  been  shown 
however,  that  the  results  of  the  three-way  interchange  are  not  signifi- 
cantly better  than  those  of  the  pairwise  interchange  [29]- 

Steinberg's  algorithm  [  16]  considers  a  large  subset  of  all  the 
packages  during  each  iteration  using  an  optimal  procedure  for  reposition- 
ing that  subset.   The  basic  subset  used  in  Steinberg's  algorithm  is  an 
unconnected  set  of  packages.   An  unconnected  set  (Fig.  9)  is  made  up  of 
packages,  such  that  no  package  in  the  set  is  connected  to  any  other  pack- 
age in  the  set.   Therefore,  the  positioning  of  any  one  package  of  an  un- 
connected set  is  completely  independent  of  the  positioning  of  the  other 
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UHCONNECTED  SET  REMAINING  ELEMENTS 


Figure  9*   An  Unconnected  Set. 
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packages  of  the  set.   The  placement  of  an  unconnected  set  of  units  in  the 
available  board  positions  (Fig.  10)  created  by  their  removal  is  therefore 
a  simple  assignment  problem  for  which  an  optimal  solution  can  be  easily 
found  [ U] .   The  positioning  of  the  unconnected  set  of  units  will  always 
either  decrease  or  not  change  the  total  wire  length  of  the  board. 

There  are  many  unconnected  sets  that  can  be  formed  from  any 
given  set  of  packages.   The  process  for  constructing  an  unconnected  set 
starts  by  choosing  a  package  at  random  and  proceeds  by  adding  to  the  set 
only  those  packages  which  are  not  connected  to  members  of  the  set.   This 
process  is  continued  until  a  set  of  the  desired  size  has  been  formed  or 
until  no  more  packages  can  be  added  to  the  set.   An  unconnected  set  which 
can  not  be  added  to,  is  known  as  a  maximal  unconnected  set.   The  size  of 
the  unconnected  set  to  be  used  will  be  largely  determined  by  the  com- 
puting power  available  for  solving  the  assignment  problem.   It  is  always 
preferable  to  use  maximal  unconnected  sets  when  possible  to  ensure  the 
greatest  flexibility  in  the  assignment. 

Rutman  [17]  suggested  an  improvement  to  Steinberg's  algorithm 
to  produce  better  placements  and  to  speed  up  the  convergence  of  the  algo- 
rithm.  After  some  predetermined  number  of  Steinberg  iterations  Rutman 
inserts  an  interchange  step  which  decreases  the  length  of  the  longest 
wires.   :;hen  Steinberg's  algorithm  is  applied  for  a  few  more  iterations. 
Rutman ' s  interchange  seems  to  help  keep  Steinberg's  algorithm  from  stop- 
ping at  a  local  minimum. 
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Figure  10.   Board  Positions  of  an  Unconnected  Set. 
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Another  iterative  placement  method  employs  a  relaxation  prin- 
ciple.  After  an  initial  placement  is  established  a  measurement  is  made 
for  each  package  which  determines  how  strongly  it  is  connected  to  other 
packages.   This  measurement  represents  the  degree  to  which  one  package 
wants  to  be  close  to  another.   Each  of  these  measurements  can  in  turn  be 
represented  by  a  force  which  acts  to  move  a  package  closer  to  the  pack- 
ages it  connects  to.   An  equilibrium  position  which  balances  the  forces 
on  each  package  is  then  computed  for  all  packages.   The  new  placement  is 
then  formed  by  moving  all  packages  to  the  position  closest  to  their 
equilibrium  positions  with  the  constraint  that  no  two  packages  may  occupy 
the  same  position.   Other  relaxation  methods  are  quite  similar  to  this 
description  and  are  beginning  to  appear  in  the  literature  [11].   One 
difficultly  in  implementing  a  relaxation  algorithm  is  the  problem  of 
representing  net  connection  so  that  they  realistically  influence  position- 
ing during  each  iteration. 

U.3.2   The  Pairwise  Interchange  Program 

The  pairwise  interchange  program  exhaustively  attempts  all 
possible  interchanges  of  two  packages.  The  change  in  the  total  wire 
length  of  the  board  that  results  from  each  interchange  is  determined, 
and  only  those  interchanges  which  decrease  the  total  wire  length  are 
actually  made.  If  any  interchanges  are  performed  during  this  process 
then  the  board  positions  will  be  different  at  the  end  than  they  were 
to  begin  with.  Further  improvement  may  be  possible  by  simply  trying 
all  possible  interchanges  on  this  new  board  placement.   Continued 
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iteration  through  all  possible  pairwise  interchanges  may  or  may  not 
continue  to  improve  the  total  wire  length  of  the  board.   As  soon  as 
one  iteration  fails  to  produce  an  improvement  a  local  optimum  has  been 
reached  which  has  the  property  that  no  interchange  of  any  two  packages 
will  result  in  a  reduced  total  wire  length  for  the  board.   This  local 
optimum  is  not  unique.  Its  configuration  depends  on  the  initial  place- 
ment of  the  board. 

Implementing  the  Pairwise  Interchange  method  is  quite  straight 
forward;  however,  some  care  must  be  employed  to  keep  the  execution  time 
from  becoming  unreasonable.   When  considering  the  interchange  of  two 
packages,  it  is  not  practical  to  measure  the  entire  wire  length  of  the 
board  before  and  after  the  interchange.   Only  the  change  in  the  total 
wire  length  is  important.   If  all  of  the  connections  to  the  two  packages 
in  question  are  point-to-point  connections  this  calculation  becomes 
trivial.   The  difference  in  total  wire  length  is  simply  the  change  of 
length  of  each  connection.   Frequently,  however,  a  package  will  be  con- 
nected to  a  net  which  is  a  single  connection  of  more  than  two  points  on 
the  board.   The  amount  of  wire  needed  to  connect  a  package  to  a  net  can 
not  be  determined  without  reconstructing  the  entire  net  each  time  this 
information  is  needed.   Since  the  structure  of  the  net  may  be  changed 
significantly  by  moving  one  package  the  change  in  total  wire  length  will 
only  be  correct  if  it  is  determined  by  taking  the  difference  of  the 
entire  length  of  each  net  for  the  two  package  positions.   The  difference 
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in  total  wire  length  measured  in  this  manner  will  he  the  same  as  when  the 
total  wire  length  is  computed  for  each  position  and  then  the  difference 
taken.   The  results  will  therefore  be  the  same  while  a  great  increase  in 
speed  will  he  achieved. 

The  algorithmic  description  of  the  pairwise  interchange  pro- 
gram is  given  below,  where  P(l)  represents  the  Ith  package,  and  N  is  the 
number  of  packages. 

Step  1.    Initialize.   Set  initial  positions  of  packages  on  the  board. 

Set  I  to  1  and  J  to  2.   Set  IND  to  0. 
Step  2.   Measure  the  wire  length  of  the  connections  to  P(l)  and  P(j). 
Step  3.    Interchange  P(l)  and  P(J). 
Step  h.        Measure  the  wire  length  of  the  connections  to  P(l)  and  P(j) 

in  their  new  positions  and  determine  the  total  change  in 

wire  length  (Ato). 
Step  5.    If  AW  is  positive,  interchange  P(l)  and  P(J)  returning  them  to 

their  original  positions.   Otherwise  set  IND  to  1. 
Step  6.    If  I   N  go  to  Step  7-   Otherwise  if  J  =  N  set  J  to  1  and  I 

to  I  +  1  and  go  to  Step  2.   Otherwise  set  J  to  J  +  1  and  go 

to  Step  2. 
Step  7.    If  IND  =  0  then  done.   Otherwise  go  to  Step  1. 
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U.3«3  Pairwise  Interchange  Results 

Since  the  iterative  placement  programs  required  large  amounts  of 
computer  time,  a  set  of  only  five  boards  was  chosen  to  compare  them.   The 
complete  net  lists  for  these  five  boards  are  given  in  Appendix  A.   Each  of 
the  iterative  placements  used  the  Serial  Placement  results  as  initial 
placements.   Also,  the  iterative  placement  interchanges  were  restricted 
to  the  board  positions  filled  by  the  Serial  Placement  program. 

Each  iteration  of  the  Pairwise  Interchange  program  attempts  all 
possible  pairwise  interchanges  of  packages  on  the  board.   These  iterations 
are  repeated  until  one  produces  no  improvement  in  the  wire  length  indi- 
cating a  locally  optimal  solution.   The  Pairwise  Interchange  Results  in 
Table  h   include  this  final  iteration.   The  execution  time  for  each  iter- 
ation of  a  given  board  placement  remains  about  the  same,  decreasing 
slightly  as  the  number  of  interchanges  decrease.   The  execution  times 
given  in  Table  k   are  the  processor  times  for  execution  on  a  Burroughs  6500 
computer  and  can  be  directly  compared  to  the  Serial  Placement  times. 

k.3-^-        Implementation  of  Steinberg's  Algorithm 

Steinberg's  placement  algorithm  [  16]  was  the  most  difficult  of 
the  three  methods  to  implement;   therefore,  it  was  implemented  in  its  most 
simplified  form.   The  algorithm  consists  first  of  finding  a  set  of  pack- 
ages such  that  a  member  of  the  set  does  not  connect  to  any  other  member 
of  the  set.   Since  the  members  of  such  a  set  are  independent,  they  can  be 
interchanged  by  a  simple  procedure  which  will  insure  that  the  total  wire 
length  of  the  board  will  be  improved  or  at  worst  stay  the  same.   Repeated 
application  of  tiiis  procedure  to  different  sets  of  packages  will  continue 
to  decrease  the  total  wire  length  until  some  local  optimum  is  reached. 
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Table  h.        Pairwise  Interchange  Results 


Board  No.  of       No.  of  Inter-  Execution    Starting  Final   Improve- 
Name   Iterations   Changes        Time  (Min. )  Wire      Wire   ment 

Length    Length 


FIRDB 

2 

lk 

2h 

725 

700 

3.5$ 

FDQA 

k 

57 

8)4 

1230 

1085 

12     % 

ATP07 

3 

U5 

55 

li+29 

1320 

L% 

TCRFLD 

3 

kl 

67 

2318 

22^3 

3     % 

IICR1 

k 

lk8 

136 

3306 

281+5 

11+  i 
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A  set  of  packages  which  have  no  connections  to  other  packages 
within  the  set  is  called  an  unconnected  set  and  is  illustrated  in 
Figure  9-   Such  a  set  can  he  easily  formed  in  the  following  manner: 

Step  1.    Initialize.  Mark  all  packages  to  he  unconnected. 

Step  2.    Select  one  package  at  random.   If  it  is  marked  connected  repeat 

Step  2. 
Step  3-   Mark  the  selected  package  and  all  packages  it  connects  to,  as 

connected.   Enter  the  selected  component  in  the  unconnected  set. 
Step  k.        When  the  required  number  of  packages  are  in  the  unconnected  set 

or  when  all  of  the  packages  have  been  marked  unconnected,  stop. 

Otherwise  return  to  Step  2. 
When  an  unconnected  set  is  formed  such  that  no  other  package  can  he  added 
to  the  set,  it  is  called  a  maximal  unconnected  set.   The  above  descrip- 
tion represents  the  implementation  which  was  employed;  therefore,  the 
unconnected  sets  are  formed  in  a  random  manner.   The  size  of  the  uncon- 
nected sets  is  kept  as  large  as  possible  and  often  times  maximal  uncon- 
nected sets  are  used. 

Since  the  elements  of  an  unconnected  set  are  by  definition  not 
directly  connected  to  one  another,  the  positioning  of  each  member  of  an 
unconnected  set  is  completely  independent  of  the  positioning  of  the  other 
members.   Therefore,  the  problem  of  optimally  placing  an  unconnected  set 
of  packages  with  respect  to  minimum  wire  length  reduces  to  a  simple  linear 
assignement  problem  which  can  be  quickly  solved  by  Munkres  Algorithm  [  h] . 
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There  is  one  small  problem  which  must  be  handled  properly.  In  setting  up 
the  assignment  problem  a  measurement  must  be  made  of  the  amount  of  wire 
needed  to  connect  a  package  in  each  of  the  available  positions.  As  was 
the  case  in  the  Pairwise  Interchange  method,  each  time  a  net  is  encoun- 
tered during  this  measurement,  the  entire  net  must  be  reconstructed  and 
the  entire  net  wire  length  must  be  added.  Each  entry,  C. .,  of  matrix  C 
is  therefore  the  wire  length  used  in  connecting  package  i  in  position  j. 

The  difference,  c.  .  -  c,  ,  gives  the  exact  change  in  wire  length  for 
ij    lk 

moving  package  i  from  position  j  to  position  k. 

The  following  algorithmic  description  of  Munkres  method  is 
given  by  Rutman  [17]  in  his  implementation  of  Steinberg's  algorithm. 

Preliminaries 

In  the  matrix  [C],  no  lines  are  covered  and  no  zeros  are 
starred  or  primed.   Consider  row  1  of  the  matrix.   Find  the 
smallest  element  in  row  1,  and  call  it  h.   Subtract  h  from 
each  element  of  row  1.   In  the  process  of  subtracting  h,  some 
element  (or  elements)  of  row  1  become  zero.   Whenever  an  element 
becomes  zero  and  if  there  is  no  starred  zero  in  the  row  and  none 
in  its  column,  star  the  zero  and  cover  the  column  containing  the 
zero.   If  there  is  no  zero  star  in  its  column  but  there  is  one 
in  its  row,  add  the  matrix  coordinates  of  the  zero  to  the  zero 
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A  list  (-unless  the  zero  A  list  is  already  full).   Do  the  same 
for  each  row  of  the  matrix.*  If  N  columns  are  covered,  the 
starred  zeros  form  the  desired  result,  and  the  problem  is 
finished.   If  less  than  N  columns  are  covered,  go  to  Step  1. 
Step  1 

Take  the  coordinates  of  a  zero  from  the  zero  list,  popping  up 
the  zero  A  list.   If  the  zero  is  covered,  push  the  coordinates 
of  the  zero  into  the  top  of  the  zero  B  list  and  take  another 
zero  from  the  zero  A  list.   Continue  until  a  non-covered  zero 
is  found  or  until  the  zero  A  list  is  depleted.   If  the  zero  A 
list  is  depleted  and  flag  F  is  set  search  the  matrix  for  an 
uncovered  zero.   If  the  zero  A  list  is  depleted  and  flag  F  is 
reset,  go  to  Step  3- 

Assume  an  uncovered  zero  is  found.   Prime  the  zero,  then 
consider  the  row  containing  it.   If  there  is  no  starred  zero 
in  this  row,  go  at  once  to  Step  2.   If  there  is  a  starred  zero 
in  the  row,  cover  the  row  and  uncover  the  column  of  the  starred 
zero.   Look  for  any  uncovered  zeros  in  this  new  uncovered 
column.   If  any  exist,  add  their  coordinates  to  the  top  of  the 
zero  A  list  (if  the  zero  A  list  overflows,  set  flag  F).   Then 
go  to  beginning  of  Step  1. 
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Note  that  at  this  time  the  zero  A  list  'if  sufficiently  large)  will 
contain  the  coordinates  of  every  uncovered  zero  if  any  exist.   If 
there  are  too  many  zeros  for  the  zero  list  to  hold,  flag  F  will  be 
set.   Otherwise,  flag  F  is  reset. 
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Step  2 

There  is  a  sequence  of  alternating  starred  and  primed  zeros, 
constructed  as  follows:   Let  Z  denote  the  uncovered  0  (there 
is  only  one).   Let  Z*  denote  the  0*  in  Z  's  column  (if  any). 
Let  Z  denote  the  0   in  Z  ' s  row  (if  Z  exists,  its  column  is 
not  covered  since  Zn   is  in  its  column  and  Zn  is  not  covered,  so 
its  row  must  be  covered.   Hence  there  is  a  0   in  this  row  (see 
Step  1).   Let  Z  denote  the  0   in  Z  ' s  column  (if  any). 
Similarly,  continue  until  the  sequence  stops  at  a  0  which  has 
no  0   in  its  column  (Munkres  proves  such  a  0  exists  and  the 
sequence  is  unique)). 

Now  unstar  each  starred  zero  of  the  sequence,  and  star  each 
primed  zero  of  the  sequence.   Erase  all  primes  (that  is,  remove 
the  zero  prime  coordinates  from  vector  C  ) .   Uncover  every  row 

r  P 

and  cover  every  column  containing  a  0  .   If  N  columns  are 
covered,  the  starred  zeros  form  the  desired  result  and  the 
algorithm  is  finished.   Otherwise,  empty  the  zero  B  list  into 
the  bottom  of  the  zero  A  list  and  go  to  Step  1. 
Step  3- 

Let  h  denote  the  smallest  uncovered  element  of  the  matrix; 
it  will  be  positive.  Add  h  to  each  twice-covered  element. 
Subtract  h  from  each  uncovered  element.  In  the  process  of 
subtracting  h,  add  the  coordinates  of  any  new  zeros  to  the 
zero  A  list.  Return  to  Step  1  without  altering  any  stars, 
primes,  or  covered  lines. 
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U.3'5  Steinberg's  Placement  Results 

The  Steinberg  Placement  program  was  tested  on  the  same  problems 
as  the  Pairwise  Placement  program  (U.3«3)«   The  results  of  the  Steinberg 
placements  are  presented  in  Table  5-   Each  iteration  involves  choosing 
and  repositioning  one  unconnected  set.   The  program  was  stopped  when  50 
consecutive  iterations  produced  a  decrease  in  wire  length  of  less  than  10 
units.   For  each  placement  except  that  of  board  IICR1  it  appeared  that  no 
further  improvement  would  be  made  in  the  wire  length.   The  placement  of 
IICR1  had  improved  by  15  units  in  each  of  the  last  two  sets  of  25  iter- 
ations and  would  probably  continue  to  improve  slightly.   It  was  termina- 
ted after  one  hour  of  processor  time  for  monetary  reasons.   The  Steinberg 
Placement  program  was  run  on  a  Burroughs  67OO  computer  which  is  a  faster 
modified  version  of  a  6500.   The  execution  times  for  Steinberg  results 
can  not  be  directly  compared  to  other  placement  execution  times.   The 
basic  clock  speed  of  the  6500  and  67OO  are  the  same  but  the  67OO  is  faster 
on  some  operations.   The  conclusion  indicated  is  that  the  Steinberg 
Placement  program  is  faster  than  the  Pairwise  Placement  program,  but  not 
twice  as  fast. 
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Table   5.      Steinberg's  Algorithm  Results 


Board       No.    of 
Name  Iterations 


Size  of                No.    of         B67OO  Execution     Starting            Final  Wire       Improve  - 
Unconnected        Inter-          Time    (Min. )              Wire  Length      Length                ment 
Set  Changes  


FIRLB 

100 

Max  (  8-1?) 

k 

8 

725 

702 

3  % 

FDQA 

150 

Max  (15-20) 

23 

29 

1230 

1122 

9  % 

ATP07 

150 

Max  (25-30) 

32 

h9 

li+29 

1320 

7.53 

TCKFLD 

150 

30 

32 

33 

2318 

2181 

5.5S 

IICR1 

150 

Max  (25-30) 

75 

62 

3306 

2733 

17  % 

h.k     Comparison  of  Results 

The  results  of  applying  the  Channel  Routing  program  to  the 
Pairwise  and  Steinberg  placements  are  presented  in  Table  6.   These  results 
are  used  to  measure  the  effectiveness  of  applying  iterative  placement 
algorithms  to  serial  initial  placements.   The  only  clear  conclusion  is 
that  the  change  in  wire  length  does  not  effectively  predict  the  change 
in  wireability  as  defined  in  Section  1+.2.3.   Both  the  Pairwise  and 
Steinberg  program  produce  improvements  in  wireability  in  some  cases  but 
in  most  cases  no  change  in  wireability  occurs.   Generally,  not  enough  im- 
provement is  made  to  justify  the  computer  time  involved  in  the  iterative 
techniques  used  in  this  study. 
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5 .    ROUTING 

5.1  Review 

5.1.1  Lee ' s  Algorithm 

Lee's  algorithm  [20]  is  an  exhaustive  search  technique  which 
always  finds  the  minimum  distance  path  between  two  points  on  a  plane,  if 
such  a  path  exists.   The  plane  is  first  divided  into  a  very  fine  grid 
where  the  length  of  each  side  of  a  grid  square  is  equal  to  the  minimum 
distance  between  parallel  running  lines  on  the  plane  (Fig.  11).   The  grid 
square  containing  one  of  the  two  points  to  be  connected  is  labeled  the 
origin  (0)  while  the  grid  square  containing  the  other  point  is  labeled 
the  destination  (d).   The  path  finding  algorithm  begins  by  labeling  the 
four  grid  squares  immediately  adjacent  to  the  origin  with  the  number  1 
if  they  are  available  to  contain  part  of  a  path.   Next,  all  of  the  avail- 
able squares  that  are  immediately  adjacent  to  squares  containing  l's  are 
labeled  with  the  number  2.   In  general,  at  any  step  K,  all  of  the  avail- 
able squares  which  are  immediately  adjacent  to  squares  labeled  K-l  are 
assigned  the  label  K.   This  procedure  continues  until  the  destination 
square  is  encountered  at  which  time  the  path  can  be  constructed  by  follow- 
ing the  reverse  sequence  of  numbers  from  the  destination  square  back  to 
the  origin.   Several  minimum  paths  may  exist  between  the  two  points  to 
be  connected,  so  some  additional  rule  must  be  chosen  to  determine  which 
path  will  be  used.   Such  a  rule  might  simply  be  to  always  travel  as  far 
as  possible  in  one  direction  before  making  a  turn. 

There  are  two  major  drawbacks  to  Lee's  algorithm.   First  of  all, 
the  number  of  grid  squares  that  must  be  considered  is  very  large  since 
each  one  is  so  small.   This  fact  causes  the  amount  of  storage  needed  to 
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Figure  11.   Lee's  Algorithm. 
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implement  the  algorithm  to  he  very  large.   This  storage  requirement  can 
be  greatly  reduced  hy  using  a  simplified  labeling  sequence  as  suggested 
by  Ackers  [25].   Rather  than  recording  the  distance  of  each  grid  square 
from  the  origin,  a  pattern  of  two  l's  following  by  two  2's  is  generated 
emanating  from  the  origin.   A  minimum  path  can  be  constructed  by  retrac- 
ing this  pattern  from  the  destination  back  to  the  origin  and  its  length 
can  be  determined  while  retracing.   The  storage  requirement  for  each  grid 
square  will  thus  be  reduced  to  two  bits.   Even  with  this  improvement  the 
storage  requirement  is  large.   The  second  major  drawback  of  Lee's  algo- 
rithm is  the  amount  of  computation  time  required.   The  number  of  oper- 

2 
ations  needed  to  find  a  path  of  length  n  is  proportional  to  n  which  is 

responsible  for  the  fact  that  the  amount  of  computation  time  used  is  un- 
reasonable for  large  wire  routing  problems. 

The  main  advantage  of  Lee's  algorithm  is  that  it  will  always 
find  the  minimum  path  between  two  points,  if  any  possible  path  exists. 
Such  an  algorithm  is  most  useful  when  only  a  few  remaining  connections 
need  to  be  made  on  an  almost  wired  board.   The  problem  with  wiring  an 
entire  board  using  Lee's  algorithm  is  that  each  connection  is  finalized 
as  soon  as  it  is  found  and  these  finalized  connections  may  interfere  with 
future  attempts  to  construct  connections.   This  interference  may  only 
cause  a  slight  increase  in  the  length  of  a  future  path^  but  it  may  also 
unnecessarily  eliminate  the  existence  of  any  path  for  some  connections. 
It  has  been  found  that  these  adverse  effects  can  be  minimized  by  always 
connecting  the  shortest  wires  first  and  then  the  longer  ones.   In  any 
event,  only  one  connection  is  considered  at  a  time  so  that  optimizing  the 
wiring  of  an  entire  board  should  not  be  expected. 
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5.1.2   Line  Routing 

One  alternative  to  Lee's  algorithm  is  to  create  a  series  of  line 
segments  rather  than  looking  at  each  grid  square  individually.  Methods 
which  use  this  approach  will  be  referred  to  as  line  routing  techniques. 
One  line  routing  algorithm  was  developed  by  Hightower  [2.1]  which  is  brief- 
ly described  in  the  following  explanation. 

The  path  is  constructed  from  both  the  origin  and  destination 
points  simultaneously.   From  the  origin  a  verticle  line  segment  is  con- 
structed which  extends  in  both  directions  as  far  as  possible  without  inter- 
secting any  finalized  connection  or  obstacle  on  the  board.   A  similar  line 
segment  is  constructed  horizontally  at  the  destination  point.   Intersection 
between  any  line  segment  connected  to  the  origin  and  any  line  segment  con- 
nected to  the  destination  indicates  that  a  path  has  been  found  and  the 
procedure  can  be  terminated.   If  no  intersection  is  found  an  escape  line 
is  constructed  from  each  of  the  line  segments  generated  by  the  previous 
iteration.   An  escape  line  is  a  line  perpendicular  and  intersecting  a 
previous  escape  line  which  extends  the  horizontal  or  vertical  boundaries 
established  by  the  set  of  previous  escape  lines.   This  procedure  of  find- 
ing escape  lines  is  repeated  until  a  path  is  found  or  until  no  further 
escape  lines  can  be  found,  indicating  that  no  path  exists. 

While  the  line  routing  algorithm  of  Hightower  does  not  insure 
that  the  minimum  path  will  always  be  found,  it  does  have  distinct  advan- 
tages over  Lee's  algorithm.   The  amount  of  storage  space  required  is  re- 
duced because  only  information  about  existing  line  segments  must  be  main- 
tained.  Also,  the  number  of  operations  performed  is  greatly  reduced  so 
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that  significant  time  savings  are  realized.   As  with  Lee's  algorithm, 
Hightower's  line  routing  algorithm  considers  only  one  connection  at  a  time 
so  that  wire  length  of  succeeding  connections  may  be  greatly  affected. 

5.1.3   Cellular  Wiring 

Wire  routing  using  the  cellular  modeling  technique  has  been 
introduced  by  Hitchcock  [ 23] •   This  method  of  wire  routing  can  be  viewed 
as  a  modification  of  Lee's  algorithm  where  the  grid  squares  are  enlarged 
so  that  several  wires  can  pass  through  one  cell  (the  enlarged  grid  square) 
without  interf er  ing  with  each  other.   The  size  of  these  cells  is  optional 
and  Hitchcock  chose  to  have  the  size  and  shape  depend  on  the  physical 
location  of  package  pins  on  the  board.   Each  cell  has  four  edges  through 
which  wires  can  pass  the  capacity  of  each  edge  is  determined  by  the  number 
of  wires  which  can  fit  through  when  placed  at  minimum  spacing.   Starting 
from  the  cell  containing  the  origin  a  list  of  reachable  cells  is  obtained 
which  is  expanded  in  a  similar  manner  to  Lee's  technique.   This  process 
is  repeated  until  the  destination  is  encountered  at  which  time  the  path 
can  be  constructed. 

The  internal  structure  of  each  cell  need  not  be  finalized  until 
after  all  connections  have  been  made.   The  fact  that  a  wire  passes  through 
a  cell  can  be  noted  by  simply  indicating  the  edge  that  the  wire  enters  and 
the  edge  which  that  wire  leaves.   A  cell  is  determined  to  be  reachable  if 
a  wire  segment  in  an  adjoining  cell  can  reach  the  edge  between  them  and 
if  the  capacity  of  that  edge  has  not  already  been  filled.   Once  a  wire 
segment  enters  one  edge  of  a  cell  it  is  possible  to  determine  which  edges 
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are  available  for  that  wire  segment  to  leave.   The  availability  of  an  edge 
depends  on  whether  the  capacity  of  that  edge  has  been  filled  and  also  on 
the  topology  of  the  wire  segments  passing  through  the  cell.   For  example, 
if  a  wire  segment  already  passes  through  the  east  and  west  edges  of  a 
cell,  then  the  north  edge  will  not  be  available  to  a  wire  segment  enter- 
ing from  the  south. 

The  cellular  wire  routing  technique  does  not  insure  minimum 
wire  length  for  each  path;  however,  it  does  produce  improvements  over 
Lee's  algorithm  by  reducing  the  amount  of  storage  space  required  and  by 
significantly  reducing  the  computation  time.   Since  the  search  procedure 
is  the  same  as  Lee's,  the  number  of  operations  needed  to  find  a  path  of 
length  n  (where  n  is  now  the  number  of  cells)  is  still  n  .  Although  n 
will  be  smaller  for  the  cellular  approach  since  the  grid  size  is  larger, 
the  increase  in  operations  will  again  be  quadratic  as  increasing  board 
sizes  are  considered.   Hitchcock's  approach  does  have  one  distinct  ad- 
vantage over  Lee's  and  Hightower's  algorithms  in  that  none  of  the  con- 
nections are  completely  finalized  until  all  of  the  connections  have  been 
formed,  so  that  a  connection  may  have  fewer  detrimental  effects  on  the 
possibility  of  finding  succeeding  connections  and  on  the  amount  of  wire 
used  in  constructing  succeeding  connections. 

5.1.U  Two -Layer  Routing 

The  previously  discussed  routing  algorithms  have  been  explained 
in  terms  of  making  connections  on  a  single  layer  of  a  printed  circuit 
board.   Lee's  algorithm  5. 1.1  has  been  extended  to  a  two-layer  wiring  en- 
vironment by  Heiss [ 2^] .   The  technique  is  simply  to  extend  the  search 
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pattern  on  both  layers  of  the  board  simultaneously,  and  add  a  predeter- 
mined distance  penalty  for  changing  layers.   This  method  has  all  the  time 
and  storage  difficulties  of  Lee's  algorithm,  only  doubled.   A  similar  ex- 
tension can  be  applied  to  cellular  routing  5.1.3  in  order  to  provide  two- 
layer  capability.   The  extension  suggested  by  Hightower  [21]  for  apply- 
ing line  routing  to  a  two-layer  board  is  the  obvious  solution  which  is 
to  fill  up  one  layer  without  crossovers  and  then  begin  on  a  new  layer 
to  attempt  the  remaining  connections.   The  problem  with  each  of  these  ex- 
tensions is  that  they  do  not  take  full  advantage  of  the  possibilities  of 
two -layer  routing. 

The  line  routing  algorithm  explained  by  Mikami  and  Yabucki  [22] 
uses  an  attack  similar  to  that  of  Hightower  with  the  exception  that  all 
vertical  wire  segments  are  located  on  one  side  of  a  two-layer  board  and 
all  horizontal  wire  segments  are  located  on  the  opposite  side.   Via  holes 
are  therefore  required  to  correspond  to  the  end  points  of  each  wire  seg- 
ment.  Hightower ' s  routing  program  is  capable  of  producing  similar  results 
by  running  in  a  "crossover"  mode  with  the  resulting  wire  segments  being 
assigned  to  horizontal  and  vertical  layers  with  appropriate  vias.   In 
fact,  although  he  does  not  say  so,  it  appears  that  this  is  exactly  the 
method  he  used  to  produce  his  "Two  Sided  Board"  example. 

Stanley  Lass  introduced  a  method  using  a  stepping  aperture  [26] 
which  was  specifically  designed  for  two  layer  routing  in  an  environment 
containing  a  fixed  array  of  vias.   Lass  first  wires  all  connections  on 
the  board  without  regard  for  conflicts  between  connections.   A  small 
aperture  is  then  passed  over  the  board  with  finalized  wiring  being 
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performed  only  within  the  current  boundaries  of  the  aperture.   If  any 
wiring  can  not  be  completed  within  the  aperture,  an  attempt  is  made  to 
shift  the  connection  concerned  so  that  it  may  be  completed  within  a  suc- 
ceeding aperture  position.   Connections  can  generally  be  shifted  only  to 
the  nearest  aperture  positions  without  greatly  increasing  their  wire 
length.   Therefore,  wiring  failures  will  occur  when  one  area  of  the  board 
becomes  very  crowded  as  well  as  when  the  entire  board  area  becomes  filled. 
Lass's  technique  embodies  the  advantages  in  time  and  storage  provided  by 
line  routing,  and  has  the  added  flexibility  of  allowing  connections  to  be 
readjusted  after  their  initial  placement. 

5.2   Channel  Routing 
5.2.1  Objectives 

The  channel  routing  algorithm  proceeds  in  a  manner  quite  similar 
to  the  stepping  aperture  approach  of  Lass  5.I.U.   All  of  the  connections 
to  be  made  on  a  board  are  initially  routed  along  the  large  open  areas  of 
the  board,  called  spaces,  and  then  a  second  pass  of  the  algorithm  final- 
izes the  wiring  within  these  spaces.   None  of  the  connections  are  final- 
ized until  all  connections  have  been  tentatively  assigned  and  a  great  deal 
of  flexibility  exists  for  rerouting  connections  depending  on  localized 
routing  conditions.   The  aperture  used  in  channel  routing,  a  space,  is 
much  larger  than  the  aperture  used  by  Lass.   The  basis  of  the  channel 
routing  algorithm  is  an  efficient  algorithm  for  assigning  wire  positions 
optimally  within  a  large  aperture  which  results  in  great  speed.   The 
storage  requirements  are  kept  low  by  using  one  word  of  storage  (about  U8 
bits)  for  each  line  segment. 
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The  channel  routing  algorithm  is  designed  to  be  used  in  routing 
two-layer  printed  circuit  boards  which  have  the  following  properties.   The 
types  of  component  employed  is  a  dual  inline  integrated  circuit  package. 
These  packages  are  arranged  on  the  printed  circuit  board  in  straight  rows 
and  columns  (Fig.  1).   Also  there  must  be  a  capability  for  unlimited 
"floating"  via  holes.   The  positions  of  these  vias  are  determined  by  the 
routing  program  since  it  assigns  all  vertical  wire  segments  to  one  side 
of  the  board  and  all  horizontal  wire  segments  to  the  other.   All  connec- 
tions between  vertical  and  horizontal  wire  segments  are  made  by  means  of 
via  holes. 

5.2.2  Spaces  and  Channels 

The  channel  routing  technique  considers  the  printed  circuit 
board  to  be  subdivided  into  areas  called  spaces  which  are  in  turn  sub- 
divided into  channels.   A  space  is  an  area  of  a  board  which  extends  from 
one  edge  to  the  other  and  may  be  of  any  desired  width.   The  channel  rout- 
ing technique  uses  spaces  which  cover  the  board  as  shown  in  Figure  12. 
The  side  of  the  board  to  which  all  vertical  wire  segments  are  assigned  is 
divided  into  vertical  spaces  and  the  side  to  which  all  horizontal  wire 
segments  are  assigned  is  divided  into  horizontal  spaces.   Each  vertical 
space  includes  one  column  of  package  positions  and  half  of  the  area  on 
each  side  of  that  column.   Each  horizontal  space  includes  one  row  of 
package  pins  along  with  half  the  area  above  and  half  the  area  below.   This 
choice  of  space  boundaries  is  significant  because  they  are  not  restricted 
to  fixed  physical  features  of  the  board.   For  this  reason  space  boundaries 
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Figure   12.        Space  Arrangement, 
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can  be  repositioned  quite  easily  depending  on  the  amount  of  area  needed 
to  complete  the  -wiring.   Although  there  are  obvious  limitations,  a  maximal 
amount  of  flexibility  is  achieved  while  minimizing  the  complexity  of  the 
calculations  that  are  required.   (See  5*2. 5«) 

As  a  subdivision  of  a  space,  a  channel  also  runs  from  one  edge 
of  the  board  to  the  other.   The  width  of  a  channel  is  equal  to  the  mini- 
mum spacing  between  parallel  running  wires.   This  means  that  a  channel  may 
contain  more  than  one  wire  segment  only  if  none  of  the  wire  segments  over- 
lap any  other  wire  segment  in  that  channel.   Once  all  wire  segments  are 
assigned  to  spaces,  an  algorithm  is  applied  to  assign  these  wire  segments 
to  channels  within  the  spaces. 

5.2.3   Space  Assignment 

Each  connection  made  on  the  board  is  specified  by  a  starting 
pin  and  an  object  pin.   The  connection  itself  is  in  general  broken  up 
into  five  wire  segments  (Fig.  13)-   At  each  of  the  two  pins  a  short  ver- 
tical wire  segment  (A,E)  is  constructed  which  initially  extends  to  the 
center  of  one  of  the  adjoining  horizontal  spaces.   The  remaining  vertical 
wire  segment  (C)  can  generally  be  assigned  to  one  of  several  vertical 
spaces  with  the  lengths  of  the  horizontal  wire  segments  (B,D)  adjusted 
accordingly.   In  an  attempt  to  evenly  distribute  vertical  wire  segments 
as  much  as  possible,  this  wire  segment  (C)  is  always  assigned  to  the  ver- 
tical space  between  the  starting  and  object  pins  which  has  the  fewest 
wire  segments  already  assigned  to  it.   The  specification  of  the  two  re- 
maining horizontal  wire  segments  (B,D)  is  thereby  determined.   Connections 
which  are  formed  in  the  above  manner  will  always  be  very  close  to  minimal. 


5^ 


B 


A  ] 

t 

C 

START 

D 

i 

E 

OBJECT 

Figure  13.   A  Generalized  Connection. 


55 


In  fact,  as  long  as  all  wire  segments  remain  in  the  spaces  they  are  ori- 
ginally assigned  to,  no  connection  will  ever  be  more  than  2V  +  2H  longer 
than  its  minimum.   (Where  V  is  the  vertical  distance  between  rows  of  pack- 
ages and  H  is  the  horizontal  distance  between  columns  of  packages.) 

The  channel  routing  program  Appendix  B)  stores  the  description 
of  each  wire  segment  in  one  word  of  memory.   All  of  the  horizontal  wire 
segments  are  stored  in  one  array  and  all  the  vertical  wire  segments  in 
another.   Each  array  row  in  one  of  these  two-dimensional  arrays  corres- 
ponds to  a  space  on  the  printed  circuit  board.   Channel  assignment  with- 
in spaces  is  therefore  concerned  with  only  one  array  row  at  a  time  which 
allows  for  efficient  partitioning  to  backup  storage  in  a  multiprogramming 
environment. 

The  description  of  a  horizontal  wire  segment  is  detailed  in 
Figure  ik.      Although  ^7  bits  are  indicated  as  being  divided  into  eight 
fields,  some  of  the  fields  are  larger  than  necessary  so  that  a  reduced 
word  size  may  be  possible.   The  channel  field  is  used  to  indicate  which 
channel  this  wire  segment  is  assigned  to  within  its  space.   A  channel 
field  of  six  bits  restricts  the  size  of  spaces  to  being  less  than  6U 
channels  wide.   The  one  bit  indicator  field,  I,  is  initially  set  to  zero 
and  is  changed  to  one  when  this  wire  segment  is  assigned  to  a  channel. 
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Figure  Ik.        Data  Format  of  a  Horizontal  Wire  Segment 


The  left  pointer  field  contains  a  pointer  to  the  vertical  wire  segment 
which  connects  (through  a  via)  to  the  left  end  of  this  wire  segment. 
Actually,  the  left  pointer  contains  an  index  to  a  word  of  storage  within 
the  array  row  indicated  by  the  left  field.   A  left  pointer  field  of  nine 
bits  allows  a  maximum  of  512  wire  segments  to  be  assigned  to  each  space. 
The  right  pointer  field  has  the  same  purpose  as  the  left  pointer  field, 
except  that  it  refers  to  the  right  end  point  of  the  wire  segment.   The 
left  field  indicates  the  vertical  space  to  which  the  left  end  point  of 
this  wire  segment  is  restricted.   A  left  field  of  five  bits  corresponds 
to  a  maximum  of  32  vertical  spaces  being  defined.   The  left  offset  field 
indicates  the  exact  position  of  the  left  end  point  within  the  space 
indicated  by  the  left  field.   The  left  offset  field  is  changed  after  ver- 
tical channel  assignment  to  indicate  the  channel  to  which  the  vertical 
wire  segment  that  connects  to  the  left  end  point  is  assigned.   Therefore, 
the  size  of  the  left  offset  field  is  made  consistent  with  the  size  of  the 
channel  field  in  reflecting  the  maximum  number  of  channels  per  space. 
Combining  the  contents  of  the  left  field  and  the  left  offset  field  yields 
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one  eleven-bit  quantity  which  monetonically  sequences  the  end  points  of 
all  horizontal  wire  segments  from  right  to  left  across  the  printed  cir- 
cuit board.   Finally,  the  right  field  and  the  right  offset  field  have  the 
same  purpose  as  the  left  and  left  offset  fields  respectively,  except  that 
they  refer  to  the  right  end  point  of  the  wire  segment. 

Vertical  wire  segment  information  is  also  stored  in  words  of 
memory  which  are  divided  into  fields  as  inficated  in  Figure  lk.      The 
above  explanation  can  be  applied  to  the  use  of  vertical  wire  segment 
fields  by  substituting  the  words,  bottom  and  top,  for  the  words,  left  and 
right,  respectively  and  interchanging  the  words,  vertical  and  horizontal. 

When  space  assignment  is  complete  all  wire  segments  needed  to 
completely  wire  the  board  will  be  represented  by  words  of  storage  in  the 
horizontal  and  vertical  wire  segment  arrays.   The  final  vertical  wire 
segment  on  each  end  of  a  general  connection,  (segments  A  and  E  of  Figure 
13)  do  not  require  any  storage  however,  because  they  do  not  need  to  be 
considered  during  channel  assignments  and  can  be  easily  specified  later. 
Figure  15  shows  that  these  short  final  vertical  wire  segments  do  not  take 
up  any  vertical  channel  space,  and  since  no  two  pins  have  the  same  hori- 
zontal coordinate  within  a  horizontal  space,  these  final  wire  segments 
can  not  conflict  with  one  another.   Specifying  that  the  end  point  of  a 
horizontal  wire  segment  is  to  be  connected  to  a  pin,  (done  by  setting  the 
pointer  field  to  all  l's)  and  knowing  the  horizontal  coordinate  of  that 
end  point  is  all  that  is  required  to  completely  describe  the  vertical 
wire  segment  needed  to  complete  that  connection. 
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Figure  15.   Wiring  to  a  Package  Pin. 
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5.2.^-   Channel  Assignment 

After  space  assignment  is  completed  each  space  will  contain  a 
set  of  wire  segments.   These  wire  segments  are  represented  as  a  set  of 
intervals  having  an  upper  bound  and  a  lower  bound  (Fig.  16).   The  object 
of  channel  assignment  is  to  position  all  wire  segments  so  that  no  two 
overlap  and  to  use  the  fewest  possible  number  of  channels.   The  first 
step  in  the  procedure  is  to  search  the  list  of  intervals  for  the  element 
which  has  the  greatest  upper  bound.   This  element  is  assigned  to  the  first 
channel  and  eliminated  from  the  list.   The  list  is  then  searched  for  the 
interval  which  has  the  greatest  upper  bound  which  is  less  than  the  lower 
bound  of  the  previously  chosen  interval.   This  element  is  also  assigned 
to  the  first  channel  and  eliminated  from  the  list.   The  search  is  repeat- 
ed until  none  of  the  remaining  elements  have  an  upper  bound  which  is  less 
than  the  previous  lower  bound,  at  which  time  the  entire  process  is  repeat- 
ed for  the  next  channel.  When  all  of  the  intervals  have  been  eliminated 
from  the  list  the  channel  assignment  is  complete.   This  algorithm  always 
uses  the  minimum  possible  number  of  channels  to  finalize  the  positions 
of  all  of  the  wire  segments  in  a  given  space.   The  proof  of  minimality 
will  be  given  in  Section  5*2.6. 

When  the  channel  assignments  are  being  made,  precautions  must 
be  taken  to  ensure  that  the  wire  segments  which  must  be  joined  to  form  a 
connection  have  end  points  which  coincide.   At  the  conclusion  of  the  space 
assignment  stage,  many  conflicts  may  exist  since  all  wire  segments  are 
assumed  to  travel  down  the  center  of  the  space.   Assume  that  two  hori- 
zontal wire  segments  (.1  and  2)  have  the  same  end  point  (Fig.  17a).   If 


6o 


±5 


15 


15 


8 


18 


8 


_       7 


10 


10 


10 


SET  OF  INTERVALS 


INTERVALS 
ASSIGNED  TO  FOUR 
CHANNELS 


ALTERNATE 

MINIMAL 

SOLUTION 


Figure  16.   Channel  Assignment. 
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vertical  wire  segment  3  is  to  connect  to  2  and  vertical  wire  segment  k   is 
to  connect  to  1  then  the  two  connections  are  sharing  one  via  hole.   Chan- 
nel assignment  is  now  performed  on  all  vertical  wire  segments.   Since  the 
upper  bound  of  wire  k   is  not  less  than  the  lower  bound  of  wire  3,   these 
two  wire  segments  may  not  be  assigned  to  the  same  channel.   For  this 
reason  there  can  no  longer  be  a  via  conflict  between  connections  Ik   and  23* 
but  wire  1  may  be  in  conflict  with  wire  2  (Fig.  17"b).   If  such  a  conflict 
exists  then  wire  1  and  wire  2  can  not  be  placed  in  the  same  channel  when 
horizontal  channel  assignment  is  performed.   When  all  channel  assignment 
is  complete  there  is  no  conflict  between  connection  lk   and  connection  23 
(Fig.  17c).   Other  combinations  of  conflicting  wire  segments  can  be  form- 
ed, but  the  channel  assignment  proceeds  in  such  a  way  as  to  always  elim- 
inate wire  overlap  and  via  conflicts. 
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Figure  17 .      Conflict  Elimination. 
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5-2.5  Final  Positioning 

After  channel  assignment  has  been  completed  in  each  space,  the 
number  of  channels  needed  for  complete  wiring  is  determined  for  each  space. 
In  some  cases  the  number  of  channels  needed  may  surpass  the  number  of 
channels  originally  allocated  to  a  given  space.   Although  the  availability 
of  wiring  area  is  restricted  by  the  physical  layout  of  packages  on  the 
board,  the  space  boundaries  are  not  tied  to  physical  positions  as  explain- 
ed in  5.2.2.   Figure  l8a  shows  a  typical  initial  positioning  of  space 
boundaries.   The  channel  assignment  (Fig.  l8b)  appears  to  overflow  space 
B  which  would  cause  incomplete  wiring.   However,  by  moving  the  boundary 
between  space  A  and  space  B  upward  one  channel  it  becomes  possible  to  fit 
all  wires  without  overflow  (Fig.  l8c). 

Once  channel  assignment  has  been  completed  a  simple  algorithm 
can  be  applied  to  optimally  position  the  horizontal  space  boundaries. 
The  objective  of  this  procedure  is  to  minimize  the  number  of  channels 
which  will  not  fit  within  the  physical  limitations  over  the  entire  hori- 
zontal side  of  the  board.   This  algorithm  consists  merely  of  locating 
each  boundary  between  spaces  to  its  upward  most  possible  position  (i.e., 
farthest  from  the  edge  connectors  on  the  board).   A  space  boundary  can  be 
moved  upward  until  it  encounters  either  an  already  fixed  space  boundary 
or  a  physical  limitation  (either  a  row  of  pins  or  the  edge  of  the  board). 
Starting  from  the  uppermost  boundary  of  the  space  the  channels  assigned 
to  that  space  are  given  their  final  positions  working  downward  until 
either  the  set  of  channels  for  that  space  is  exhausted,  or  the  lower  phy- 
sical boundary  for  that  space  is  encountered,  at  which  time  the  remaining 
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Figure  18.   Final  Horizontal  Positioning. 
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channels  are  entered  in  an  overflow  list.   In  either  case  a  downward 
boundary  is  set  for  the  space  which  may  serve  as  the  upward  boundary  for 
the  next  space.   This  procedure  will  minimize  the  number  of  channels 
which  will  be  entered  in  the  overflow  list. 

The  final  positioning  of  channels  requires  an  update  to  the 
positions  of  the  horizontal  wire  segments  within  each  channel.   Also,  an 
update  must  be  made  to  the  endpoints  of  vertical  wire  segments  which  con- 
nect to  the  horizontal  wire  segments  that  are  moved.   These  updates  are 
quite  easily  made.   Also,  it  can  be  easily  verified  that  these  adjust- 
ments due  to  final  positioning  will  not  create  conflicts  and  will  not 
effect  the  optimality  of  the  original  channel  assignments  that  were  made. 

The  same  algorithm  can  be  applied  to  the  final  positioning  of 
vertical  channels  since  vertical  space  boundaries  are  also  free  to  move 
within  physical  limitations.   However,  in  the  case  of  final  vertical  posi- 
tioning, changes  may  be  caused  in  horizontal  wire  segments  which  will 
effect  horizontal  channel  assignment.   In  Figure  19  the  movement  of  wire 
segment  A  causes  wire  segment  B  to  change  orientation  and  therefore  con- 
flict with  wire  segment  C.   Such  a  change  in  wire  segment  orientation  can 
cause  a  change  in  the  channel  assignments.   In  Figure  19a,  wire  segments 
B  and  C  do  not  conflict,  and  could  be  assigned  to  the  same  channel, 
whereas,  in  Figure  19b,  wire  segments  B  and  C  can  not  be  assigned  to  the 
same  channel.   A  straight  forward  solution  to  this  problem  has  been 
adopted.   Vertical  channel  assignment  and  final  positioning  are  performed 
before  horizontal  channel  assignment  begins.   Final  horizontal  positioning 
and  adjustments  then  completes  the  wire  routing  process  . 
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Figure  19.   Final  Vertical  Positioning. 


5 • 2 . 6   Proof  of  Optimum  Channel  Assignment 

The  set  of  wire  segments  assigned  to  a  given  space  can  be  repre- 
sented as  a  set  of  intervals  as  previously  stated  (Fig.  16).   This  set  of 
intervals  can  be  represented  by  a  directed  graph  (Fig.  20).   The  nodes  of 
the  graph  represent  wire  segments  and  an  arrow  is  directed  from  one  node 
to  another  if  and  only  if  the  lower  bound  of  the  first  wire  is  greater 
than  the  upper  bound  of  the  other  wire.   Assigning  wire  segments  to  chan- 
nels corresponds  to  covering  the  directed  graph  which  represents  the  set 
of  wire  segments  with  a  set  of  directed  paths.   A  directed  path  is  com- 
posed of  a  set  of  nodes  which  are  connected  by  arrows  such  that  all  arrows 
point  in  the  direction  of  the  path  (dark  arrows  in  Figure  20).   Selecting 
a  path  corresponds  to  assigning  the  wire  segments  represented  by  the  nodes 
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Figure  20.   A  Directed  Graph. 
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on  the  path  to  one  channel  without  overlap.   A  path  cover  of  a  graph  is  a 
collection  of  paths  which  includes  each  node  of  the  graph  exactly  once. 
Two  nodes  in  a  directed  graph  are  said  to  he  incomparable  if  no  path 
exists  which  includes  both  nodes.   The  greatest  number  of  mutually  in- 
comparable nodes  which  can  be  found  in  the  directed  graph  must  therefore 
be  equal  to  the  minimum  number  of  paths  which  can  be  used  to  cover  the 
graph.   This  property  was  first  proven  by  Dilworth  and  the  corresponding 
theorem  bears  his  name.   The  largest  collection  of  mutually  incomparable 
nodes  is  referred  to  as  a  maximal  incomparable  set  and  in  general  several 
distinct  incomparable  sets  from  one  graph  may  be  maximal. 

To  show  that  the  channel  assignment  algorithm  is  optimal  it 
must  be  shown  that  the  number  of  channels  used  is  equal  to  the  minimum 
number  of  paths  which  can  cover  the  corresponding  directed  graph.   First 
of  all  a  method  of  constructing  paths  must  be  found  which  corresponds  to 
the  method  used  to  assign  wire  segments  to  channels.   Such  a  path  can  be 
formed  by  choosing  the  node  with  the  greatest  upper  bound  then  choosing 
the  arrow  eminating  from  that  node  which  leads  to  the  node  with  the  great- 
est upper  bound.   The  path  is  complete  when  a  node  is  reached  which  has 
no  outgoing  arrows.   The  first  step  in  the  proof  is  to  show  that  such  a 
path  which  will  be  called  a  max  chain  contains  exactly  one  member  from 
each  maximal  incomparable  set  of  the  graph.   By  definition  no  path  can 
contain  more  than  one  element  of  a  maximal  comparable  set  of  nodes. 
Assume  on  the  other  hand  that  a  max  chain  can  be  found  which  contains 
no  members  of  a  given  maximal  incomparable  set.   If  this  assumption  leads 
to  a  contradiction  then  the  first  step  is  demonstrated.   Since  none  of 
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the  nodes  (N  ,  ...,   N  )  are  in  a  given  maximal  incomparable  set 

(M  ,  . . . ,   M  )  they  must  all  be  comparable  with  a  member  of  that  set 

(Fig.  21).   There  is  a  node  N.  which  is  the  highest  node  with  an  incoming 

J 

arrow  which  leads  from  a  member  NL  of  M.   The  next  preceding  node  N.  must 

have  an  outgoing  arrow  which  leads  to  a  member  M  of  M.   From  the  com- 

e 

parisons  described  above  it  follows  that  the  lower  bound  of  JVL  is  greater 

than  the  upper  bound  of  N.  and  the  upper  bound  of  M  is  greater  than  the 

J  e 

lower  bound  of  VL.      Therefore  the  upper  bound  of  M  is  greater  than  the 
upper  bound  of  N . .   This  proves  that  N  is  not  a  max  chain  since  the  arrow 
from  N.  to  M  was  not  chosen.   Therefore  every  max  chain  contains  exactly 
one  member  from  each  maximal  incomparable  set.   Eliminating  the  nodes 
along  a  max  chain  from  the  directed  graph  reduces  the  size  of  each  max- 
imal incomparable  set  by  one,  reducing  the  number  of  paths  required  to 
cover  the  graph  by  one.   Therefore  the  number  of  max  chains  needed  to 
cover  the  graph  which  is  equal  to  the  number  of  channels  used  is  always 
the  minimum. 

This  algorithm  assumes  that  each  wire  segment  is  an  indivisible 
entity.   The  question  arises  as  to  whether  fewer  channels  would  be  re- 
quired if  a  wire  segment  could  be  split  into  independent  subsections  con- 
nected by  perpendicular  wire  segments.   To  show  that  such  a  modification 
would  not  improve  the  number  of  channels  required  a  proof  will  be  given 
that  the  size  of  the  maximal  incomparable  sets  is  not  decreased.   Assume 
that  a  wire  segment  which  is  a  member  of  a  given  maximal  incomparable  set 
can  be  broken  into  several  nodes  so  that  none  are  incomparable  with  the 
maximal  incomparable  nodes.   The  lower  bound  of  any  of  these  nodes  would 
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Figure  21.      A  Generalized  Path. 


TO 


be  equal  to  the  upper  bound  of  the  following  node  to  preserve  continuity. 
Figure  11  can  again  be  used  to  show  that  a  contradiction  is  generated. 
Node  M  is  shown  comparable  with  node  M  (L(R  )  >  U(N.)  >  U(M  )).   There- 
fore such  a  division  of  one  wire  segment  can  not  reduce  the  number  of 
channels  required  to  place  a  set  of  wire  segments. 

5.2.7   Results 

The  Channel  Routing  program  (Appendix  B)  was  run  on  20  ILLIAC  IV 
CU  boards  placed  by  the  Serial  Placement  program  U.2.3*   The  results  of 
routing  within  the  package  spacing  shown  in  Figure  k   are  given  in  Table  7. 
The  density  of  wiring  is  presented  as  the  percent  of  board  area  used.   This 
figure  can  be  calculated  accurately  only  for  those  boards  which  are  com- 
pletely wired.   The  amount  of  board  space  available  is  considered  to  be 
the  total  area  up  to  the  farthest  package  row  from  the  connector  pins 
which  has  any  packages  in  it.   This  is  a  reasonable  choice,  since  the 
Channel  Routing  program  never  routes  any  wires  outside  this  area.   The 
wiring  density  for  boards  which  are  not  completely  wired  has  a  different 
meaning.   This  figure  gives  the  density  that  would  be  attained  if  the 
package  spacings  could  be  increased  to  allow  complete  wiring. 

The  speed  of  the  Channel  Routing  program  is  its  most  important 
assests.   Many  improvements  of  the  type  mentioned  in  Section  5*2.8  can  be 
made  without  raising  the  running  time  above  even  one  minute.   The  channel 
assignment  routine  which  is  the  basis  of  the  program  takes  only  two  or 
three  seconds  to  finalize  the  wiring.   Most  of  the  program  time  is  spent 
setting  up  the  wire  segment  storage.   This  includes  reading  the  wire  list 
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Table  FJ.      Channel  Routing  Results 


Board  Name 

Total 

Vertical 

Horizontal 

Routing 

Percent  of 

Wire  Length 

Overflow 

Overflow 

Time  (sec) 

Board  Area 
Used 

FIRDB 

725 

0 

1 

8 

19* 

FDS 

1102 

0 

0 

11 

30 

IWSCTL 

1159 

0 

0 

11 

28 

FDQA 

1230 

0 

0 

10 

23 

FIRCB 

1292 

0 

0 

12 

25 

FORC 

1313 

0 

0 

12 

25 

IIAA 

13^0 

0 

0 

12 

21 

FWLDF 

13^6 

0 

0 

10 

26 

ATP07 

1U29 

0 

k 

13 

29* 

MTMCTL 

1U60 

0 

0 

11 

25 

MPCTL 

1527 

0 

0 

Ik 

29 

TXFER 

1608 

0 

5 

12 

31* 

ICTLA 

1637 

0 

0 

12 

26 

MDSPLY 

1736 

16 

32 

13 

36* 

ATP05 

1851 

1+3 

0 

17 

21* 

FBUSY 

2058 

2k 

3 

15 

32* 

ATP25 

2126 

0 

0 

17 

3^ 

TCRFLD 

2318 

16 

9 

15 

33* 

ILTCL 

2U16 

37 

0 

17 

3k* 

IICR1 

3306 

k2 

78 

20 

35* 

These  percentages  are  calculated  by  increasing  the  board  dimensions  to 
those  necessary  for  100  percent  wiring. 
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and  performing  the  space  assignment.   Also,  the  data  structure  of  the 
program  is  well  suited  to  a  small  core,  multiprogramming  computer.   Ihe 
channel  assignment  routine  is  basically  interested  in  one  array  row  at  a 
time  which  keeps  data  storage  requirements  in  core  below  1000  words.   The 
entire  program  requires  about  5000  words  of  resident  core  to  run  on  a 
Burroughs  67 00  computer. 

5.2.8  Possible  Improvements 

Two  alternatives  exist  for  improving  vertical  space  assignment. 
One  is  to  run  the  entire  routing  program  once,  simply  to  determine  which 
vertical  spaces  use  too  many  channels.   This  information  can  then  be  used 
to  allocate  space  better  on  a  second  routing  attempt.   Another  possibility 
is  to  perform  vertical  channel  assignment  is  still  in  progress.   This  can 
be  easily  done  because  vertical  wire  segments  can  initially  end  only  at 
the  center  of  horizontal  spaces.  A  simple  count  kept  at  each  end  point 
position  will  reflect  the  number  of  channels  required  so  far.   A  combina- 
tion of  both  of  these  improvements  might  be  better  still. 

Changes  in  the  final  positioning  routine  may  produce  the  most 
dramatic  improvements.   Final  positioning  allows  space  boundaries  to  be 
moved  within  certain  physical  limits.   An  improvement  would  be  to  allow 
wire  segments  to  actually  cross  the  space  boundary  as  long  as  no  conflicts 
are  created.   Rather  than  having  wire  segments  cross  space  boundaries,  the 
identical  result  can  be  attained  by  allowing  space  boundaries  which  are 
not  straight  lines.   Preliminary  study  of  routing  data  indicates  that  such 
a  modification  may  increase  wiring  densities  by  five  percent.  More  soph- 
isticated final  positioning  algorithms  can  be  developed  and  should  be 
investigated. 
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In  the  event  of  wiring  failures  a  follow-up  technique  should  be 
considered  which  takes  advantage  of  the  special  properties  of  the  channel 
routing  method.   The  storage  organization  and  the  high  speed  of  the  chan- 
nel routing  program  should  make  failure  elimination  possible  without  ex- 
tensive use  of  maze  running  algorithms.   One  possibility  is  to  change  a 
number  of  space  assignments  so  as  to  reduce  localized  overcrowding  and 
then  return  to  the  original  channel  assignment  routine. 
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6.   CONCLUSIONS 

6. 1  Placement 

Several  basic  placement  algorithms  were  compared  in  Chapter  h. 
During  the  course  of  implementing  these  algorithms  some  factors  were 
found  to  greatly  influence  the  results.   The  pairwise  interchange  method 
and  Steinberg's  algorithm  were  initially  programmed  with  approximated 
wire  length  measurements.   No  significant  improvements  were  made  in  the 
initial  serial  placements.   After  these  two  programs  were  changed  so  that 
all  wire-lengths  were  exactly  measured,  they  were  able  to  make  consider- 
able improvements  on  the  initial  placements.   Also,  it  was  found,  as 
suggested  by  Garside  and  Nicholson  [29]?  that  systematic  pairwise  inter- 
change converges  faster  than  random  pairwise  interchange.   These  con- 
clusions are  not  intended  as  comparisons  of  alternative  implementations. 
The  factors  involved  are  important  because  it  was  found  that  the  algorithms 
simply  would  not  work  unless  they  were  handled  as  indicated. 

The  results  presented  in  Chapter  k   support  several  interesting 
conclusions.   The  total  wire  length  of  a  board  must  be  augmented  by  other 
measures  to  clearly  indicate  the  ease  of  wiring  that  board.   Connections 
which  leave  the  board  (edge  connector  pins)  significantly  influence  the 
wireability  of  the  board.   The  most  important  measure  however,  is  the  dis- 
tribution of  wiring  density.   These  results  indicate  that  assignment  of 
edge  connector  pins  is  very  important  and  better  results  can  be  obtained 
by  allowing  the  placement  program  to  assign  the  pin  positions.   Also,  an 
effort  should  be  made  to  incorporate  information  from  a  routing  attempt 
into  a  placement  improvement  program.   Such  an  effort  is  becoming  prac- 
tical with  the  introduction  of  fast  wire  routing  techniques  like  the 
channel  routing  algorithm  of  Chapter  5* 
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The  comparison  of  serial  and  iterative  placement  techniques 
presented  in  Table  6  yields  several  conclusions.   The  serial  placement 
method  has  a  distinct  time  advantage  and  may  produce  completely  wireable 
placements.   In  such  cases,  no  further  improvement  should  be  sought. 
Iterative  placement  algorithms  can  produce  improvements  in  wire  length 
and  wireability  when  needed  without  using  an  unreasonable  amount  of  time. 
The  iterative  placement  results  of  Chapter  h   were  obtained  with  the  pos- 
sible placement  positions  restricted  to  those  used  for  serial  placement. 
If  an  iterative  placement  algorithm  were  allowed  to  reposition  components 
to  any  position  on  the  board,  even  better  results  should  be  attainable. 
Further  comparisons  using  sophisticated  versions  of  existing  placement 
algorithms  will  provide  important  qualitative  and  quantitative  conclusions. 

6.2  Channel  Routing 

The  channel  routing  algorithm  described  in  Chapter  5  performs 
the  complete  wire  routing  function.   All  connections  which  can  be  made  by 
this  algorithm  within  the  given  board  area  are  completely  specified  with- 
out conflicts.   The  results  of  implementing  this  basic  algorithm  and  test- 
ing it  on  ILLIAC  IV  design  problems  are  very  favorable.   The  speed  of 
execution  for  such  large  problems  is  the  main  advantage  of  the  channel 
routing  approach.   The  major  disadvantage  is  that  this  algorithm  is  de- 
pendent on  the  availability  of  unlimited  via  holes  whose  positions  are  not 
fixed. 

An  implementation  of  the  basic  channel  routing  algorithm  is 
capable  of  completely  wiring  large  printed  circuit  boards  with  wiring 
densities  of  20  to  30  percent.   Wiring  failures  begin  to  occur  on  boards 
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requiring  densities  greater  than  30  percent.   These  results  are  signifi- 
cant because  several  improvements  can  be  made  in  the  basic  algorithm. 
More  sophisticated  space  assignment  and  final  positioning  routines  can 
be  implemented.   Also  a  second  pass  algorithm  could  be  developed  to  route 
as  many  failed  connections  as  possible  using  more  complicated  paths  than 
the  channel  routing  algorithm  presently  considers.   The  speed  and  flexi- 
bility of  the  basic  algorithm  will  make  improvements  possible  without 
unreasonable  costs  in  terms  of  computer  time. 
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APPENDIX  A 


The  following  pages  contain  the  signal  net  listings  of  five 
ILLIAC  IV  CU  boards.   Several  simplifications,  of  the  original  net  lists 
have  "been  made,  including  the  elimination  of  all  power  and  ground  con- 
nections and  a  consolidation  of  the  clock  buffer  circuitry  so  that  it 
appears  as  a  single  movable  package.   Also,  the  labeling  of  edge  con- 
nector pins  has  been  organized  to  facilitate  distance  measurements  for 
placement  programs  and  edge  pin  wiring  for  routing  programs.   The  edge 
connectors  should  be  considered  to  be  divided  as  shown  in  Figure  1  with 
the  groups  being  labeled  P001  through  P015.  Within  each  group  there  are 
exactly  sixteen  pins  which  are  spaced  50  mils  apart  and  are  numbered  as 
shown  in  Figure  5 >    so  each  group  can  be  treated  the  same  as  a  package. 
Actually  each  edge  connector  group  has  32  pins  with  sixteen  appearing  on 
each  side.   In  the  signal  netlists  which  follow,  no  distinction  will  be 
made  between  corresponding  edge  connector  pins  on  opposite  sides  of  the 
board.   Therefore,  one  edge  connector  pin  name  may  appear  more  than  once 
in  the  netlist.   However,  no  edge  connector  pin  is  used  more  than  once, 
so  each  occurrence  should  be  treated  as  a  separate  pin. 

The  netlists  are  listed  in  columns  so  that  the  first  entry  of 
the  second  column  follows  the  final  entry  of  the  first  column  and  so  forth. 
Each  entry  is  composed  of  l)  a  name  where  A  indicates  a  package  and  P 
indicates  a  connector  pin  group,  2)  a  pin  number  and  3)  a  source  (s)  or 
load  (L)  indicator.   Each  signal  net  is  composed  of  one  source  and  one 
or  more  loads  which  immediately  follow  the  source.   The  following  rules 
should  be  helpful  in  checking  that  the  data  is  properly  copied. 
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1.  Packages  are  named  starting  with  AOOO  sequentially  through 
the  highest  numbered  package.   No  sequence  numbers  are 
skipped. 

2.  A  package  name  with  sequence  number  N  will  not  appear  in 
a  given  entry  unless  all  package  names  with  sequence 
numbers  less  than  N  have  appeared  in  previous  entries. 

3.  Edge  connector  pin  groups  are  named  P001  through  P015 
inclusive,  and  no  sequence  number  greater  than  15  will 
follow  a  "P". 

k.        Pin  numbers  (the  second  element  of  each  entry)  must  be 

between  001  and  016  inclusive. 
5-    Each  netlist  must  begin  with  a  source  (an  entry  with  an 

S  as  its  third  element)  and  every  source  (S)  must  be 

followed  by  at  least  one  load  (L). 
6.   Each  column  after  the  first  page  has  50  entries  (1+9  on 

first  page) . 


Netlist 

Highest  Numbered 

Length  of 

Package 

Netlist 

ATP07 

A100 

960 

FDQA 

A092 

861 

FIRDB 

A051 

1+81+ 

IICR1 

A120 

1233 

TCRFLD 

A135 

995 

ATP07 
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AOOO  005  S 

A027 

013  L 

A044  004  S 

A021 

009  L 

A001  008  L 

A029 

oo4  s 

A042  014  L 

A021 

016  L 

A002  005  S 

A027 

014  L 

A045  007  S 

A048 

Oil  L 

A003  008  L 

A030 

007  s 

A042  016  L 

A019  007  S 

AOOO  002  S 

A027 

016  L 

A045  004  s 

AOOO 

Oil  L 

A001  Oil  L 

A030 

oo4  s 

A042  001  L 

AOOO  016  L 

A002  002  S 

A027 

001  L 

A020  005  S 

A024  014  L 

A003  Oil  L 

A031 

007  s 

A017  Oil  L 

A020 

008  L 

A004  002  S 

A032 

006  L 

A010  005  S 

A018 

009  L 

A005  001  L 

A031 

004  3 

A007  Oil  L 

A021 

014  L 

A006  002  S 

A032 

009  L 

A004  007  s 

A049 

013  L 

A007  001  L 

A033 

007  S 

A008  012  L 

A022 

007   S 

A008  013  L 

A032 

Oil  L 

A008  014  L 

A023 

013  L 

A009  002  S 

A033 

oo4  s 

A011  001  L 

AOOO 

009  L 

A003  Ol4  L 

A032 

012  L 

A011  Oil  L 

A024 

013  L 

A010  013  L 

A034  007  S 

A046  013  L 

A018 

008  L 

A011  008  L 

A032 

013  L 

A006  007  S 

A049 

Oil  L 

A012  002  S 

A034  004  s 

A025  016  L 

A050 

007  S 

A013  014  L 

A032 

014  L 

A010  009  L 

A051 

Oil  L 

A002  014  L 

A035 

007  S 

A010  014  L 

A052 

Oil  L 

A010  Oil  L 

A032 

016  L 

A008  Oil  L 

A050 

005  S 

A011  013  L 

A035 

004  S 

A011  009  L 

A051 

013  L 

A0l4  002  S 

A032 

001  L 

A011  016  L 

A052 

013  L 

A015  001  L 

A036 

007  s 

A046  Oil  L 

A050 

004  S 

A016  002  S 

A037 

008  L 

A009  007  S 

A053 

Oil  L 

A017  001  L 

A036 

004  s 

A002  Oil  L 

A054 

Oil  L 

A018  013  L 

A037 

009  L 

A002  016  L 

A050 

002  S 

A019  002  S 

A038 

007  s 

A025  014  L 

A053 

013  L 

A001  014  L 

A037 

Oil  L 

A010  008  L 

A054 

013  L 

A020  013  L 

A038  oo4  s 

A008  009  L 

P003 

015  S 

A021  008  L 

A037 

012  L 

A011  014  L 

A055 

Oil  L 

A022  002  S 

A039 

007  S 

A047  013  L 

A055 

007  S 

A023  014  L 

A037 

013  L 

A012  007  S 

poo4 

002  L 

AOOO  014  L 

A039 

004  S 

A013  013  L 

A055 

008  S 

A020  Oil  L 

A037 

014  L 

A002  009  L 

A050 

001  L 

A021  013  L 

A040 

007  S 

A025  013  L 

A050 

009  L 

A024  002  S 

A037 

016  L 

A008  008  L 

A020 

002  S 

A017  008  L 

A040 

oo4  s 

A047  Oil  L 

A017 

013  L 

A025  002  S 

A037 

001  L 

A014  007  S 

A010 

002  S 

A007  008  L 

A04l 

007  s 

A018  012  L 

A007 

013  L 

A026  007  S 

A042 

008  L 

A018  014  L 

A018 

002  S 

A027  008  L 

A04l 

oo4  s 

A021  001  L 

A015 

008  L 

A026  004  S 

A042 

009  L 

A021  Oil  L 

A008 

002  S 

A027  009  L 

A043 

007  S 

A048  013  L 

A005 

008  L 

A028  007  s 

A042 

Oil  L 

A016  007  S 

A021 

005  s 

A027  Oil  L 

ao43  oo4  s 

A024  016  L 

A015 

Oil  L 

A028  004  S 

A042 

012  L 

A020  009  L 

A011 

005  S 

A027  012  L 

A044 

007  S 

A020  014  L 

A005 

Oil  L 

A029  007  S 

A042 

013  L 

A018  Oil  L 

A021 

002  S 
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A015  013 

L 

A001 

005 

s 

P007 

003 

s 

A069 

Oil  L 

A011  002 

S 

A038 

Oil 

L 

A062 

012 

L 

AO68 

oo4  s 

A005  013 

L 

A038  016 

L 

A063  012 

L 

A069  013  L 

P004  015 

S 

A001 

007 

S 

P007 

oo4 

s 

A070 

005  s 

A056  009 

L 

A036 

Oil 

L 

A064 

001 

L 

A071 

Oil  L 

A056  Ol4 

L 

A036  016 

L 

P005 

Oil 

s 

A070 

004  S 

A056  oo4 

S 

A023 

002 

S 

A065 

002 

L 

A071 

013  L 

A057  011 

L 

A030 

Oil 

L 

A042 

002 

S 

A072 

005  s 

A058  Oil 

L 

A030 

016 

L 

A046 

016 

L 

A073 

Oil  L 

A056  002 

S 

A023 

ooU 

S 

A046 

oo4 

S 

A072 

004  S 

A057  013 

L 

A029 

Oil 

L 

P010 

Oil 

L 

A073 

013  L 

A058  013 

L 

A029 

016 

L 

A042 

005 

S 

poo4 

015  S 

A056  007 

S 

P009 

016 

S 

A046 

008 

L 

A067 

012  L 

A059  011 

L 

A048 

009 

L 

A046 

005 

S 

A067 

014  L 

A060  Oil 

L 

A048 

oi4 

L 

P010 

016 

L 

A069 

012  L 

A056  005 

S 

AOi+7 

009 

L 

A032 

002 

S 

A069 

014  L 

A059  013 

L 

A0U7  014 

L 

A047  016 

L 

A071 

012  L 

A060  013 

L 

A046 

009 

L 

A047 

oo4 

S 

A071 

014  L 

A06l  001 

S 

A046 

oiU 

L 

P011 

003 

L 

A073 

012  L 

A056  008 

L 

A0U9  009 

L 

A032 

005 

S 

AO73 

014  L 

A06l  002 

S 

AOl+9  014 

L 

A047 

008 

L 

A074  013  s 

A050  008 

L 

P011 

006 

S 

A047 

005 

S 

P003 

003  L 

A061  003 

S 

A048 

012 

L 

P010 

015 

L 

A051 

007  s 

A056  013 

L 

AOU7 

012 

L 

A037 

002 

S 

poo4  oo4  l 

A06l  oo4 

S 

A046 

012 

L 

A048 

016 

L 

A051 

008  S 

A050  013 

L 

A049 

012 

L 

A048  004 

S 

A074 

Oil  L 

A007  005 

S 

P013 

003 

S 

P010 

014 

L 

AO75 

013  s 

AOI45  Oil 

L 

A028 

Oil 

L 

A037 

005 

S 

A003 

004  L 

AOi+5  016 

L 

A028 

016 

L 

A048 

008 

L 

A053 

007  S 

A007  007 

S 

P009 

012 

S 

A048 

005 

S 

AO66 

009  L 

A044  Oil 

L 

A026 

Oil 

L 

POll 

oo4 

L 

poo4  007  L 

A044  016 

L 

A026 

016 

L 

A027 

002 

S 

A053 

008  S 

A003  005 

S 

A023 

012 

L 

A049  016 

L 

A075 

Oil  L 

A0U3  Oil 

L 

A001 

009 

L 

A049 

004 

S 

A075 

016  S 

A043  016 

L 

A017 

009 

L 

POll 

007 

L 

P002 

015  L 

A003  007 

S 

P013 

004 

S 

A027 

005 

S 

A053 

002  S 

A04l  Oil 

L 

A033 

Oil 

L 

A049 

008 

L 

A066 

016  L 

A04l  016 

L 

A033 

012 

L 

A049 

005 

S 

P003 

015  L 

A013  002 

S 

P009 

007 

S 

POll 

003 

L 

A053 

001  S 

A035  011 

L 

A031 

Oil 

L 

A018 

007 

S 

A075 

014  L 

A035  016 

L 

A031  016 

L 

P009 

016 

L 

A076  013  s 

A013  oo4 

S 

A013 

012 

L 

A018 

005 

S 

P003 

007  L 

A03U  Oil 

L 

A003 

009 

L 

P009 

Oil 

L 

A054  007  s 

A03U  016 

L 

A007 

009 

L 

A008 

005 

S 

A068 

009  L 

A017  005 

S 

A015 

005 

S 

P008 

012 

L 

P003 

016  L 

A040  Oil 

L 

P008 

Oil 

L 

A066 

005 

S 

A054  008  s 

A040  016 

L 

A015 

007 

S 

A067 

Oil 

L 

A076 

Oil  L 

A017  007 

S 

P008  OI6 

L 

A066 

oo4 

S 

A076 

016  S 

A039  011 

L 

A005 

007 

S 

A067  013 

L 

P002 

Oil  L 

A039  016 

L 

P009 

015 

L 

A068 

005 

S 

A054 

002  S 
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A068  016 

L 

AO66  001  L 

poii*  003  S 

A091  012  L 

P003  012 

L 

A080  002  S 

AO89  Oil  L 

A092  012  L 

A05^  001 

S 

A08l  012  L 

POlU  ooi*  s 

A093  012  L 

AO76  oil* 

L 

P009  015  L 

A090  Oil  L 

AO9I*  012  L 

A07U  016 

S 

A082  007   S 

POlU  008  S 

A095  012  L 

P002  012 

L 

A068  008  L 

A091  Oil  L 

POll*  016   S 

A051  002 

S 

A082  005  S 

P013  015  s 

A088  Oil*  L 

A070  016 

L 

AO83  Oil*  l 

A092  Oil  L 

AO89  Oil*  L 

A051  001 

S 

P011  002  L 

poii*  007  S 

A090  Oil*  L 

A071*  oil* 

L 

A082  ooi*  S 

A093  Oil  L 

A091  Oil*  L 

A077  013 

S 

AO68  001  L 

POlU  003  s 

A092  Oil*  l 

P003  003 

L 

A082  002  S 

AO9I*  Oil  L 

A093  Oil*  L 

A052  007 

S 

AO83  012  L 

P013  016  S 

A09l*  Oil*  L 

A072  009 

L 

P007  OOl*  L 

A095  Oil  L 

A095  OlU  l 

A052  008 

S 

ao81*  007  S 

poio  007  S 

P009  ooi*  s 

A077  011 

L 

A070  008  L 

A080  009  L 

AO78  009  L 

A077  016 

S 

A081*  005  s 

P013  Oil  S 

A061*  Oil  L 

P002  016 

L 

AO85  Oil*  l 

AO88  013  L 

A079  012  L 

A052  002 

S 

P007  007  L 

poio  003  s 

A065  Oil  L 

A072  016 

L 

A081*  004  s 

A080  Oil*  l 

P008  003  s 

A052  001 

S 

A070  001  L 

P013  015  s 

A062  009  L 

A077  Oil* 

L 

AO8U  002  S 

AO89  013  L 

A062  Oil*  L 

P005  015 

S 

A085  012  L 

POIO  00U  S 

A063  009  L 

A070  Oil 

L 

P007  008  L 

A082  009  L 

A063  Oil*  L 

A072  Oil 

L 

ao86  007  S 

P013  012  S 

P008  008  S 

P006  002 

S 

A072  008  L 

A090  013  L 

AO78  OlU  L 

AO66  Oil 

L 

AO86  005  s 

poio  003  s 

A061*  O.I6  L 

AO68  Oil 

L 

AO87  Oil*  l 

A082  Oil*  l 

A079  Oil*  L 

A062  007 

S 

P007  Oil  L 

P013  016  S 

A065  Oil*  l 

A051  012 

L 

AO86  ooi*  s 

A091  013  L 

P007  012  S 

AO78  005 

S 

A072  001  L 

POIO  008  S 

A062  008  L 

A053  012 

L 

AO86  002  S 

A081*  009  L 

poo8  007  s 

A079  005 

S 

AO87  012  L 

poii*  ooi*  s 

A080  008  L 

A053  oil* 

L 

P007  008  L 

A092  013  L 

AO78  013  L 

A061+  005 

S 

pool*  016  S 

POIO  Oil  S 

P005  012  S 

AO5I*  012 

L 

AO66  007  L 

A081*  oil*  L 

A080  013  L 

A065  005 

S 

AO68  007  L 

P013  007  S 

A079  013  L 

AO5I*  011+ 

L 

A070  007  L 

A093  013  L 

P007  016  S 

A062  002 

S 

A072  007  L 

poio  007  S 

A082  008  L 

A051  Oil* 

L 

P008  ooi*  s 

AO86  009  L 

A061*  Oil*  L 

A063  007 

S 

AO87  Oil  L 

P013  Oil  S 

P005  003  s 

A052  012 

L 

AO87  013  L 

A09l*  013  L 

A082  013  L 

A063  002 

S 

AO85  Oil  L 

POIO  012  S 

A065  016  L 

A052  Oil* 

L 

AO85  013  L 

AO86  Oil*  L 

poio  0.15  s 

A080  007 

S 

AO83  Oil  L 

P013  008  S 

A081*  008  L 

AO66  008 

L 

AO83  013  L 

A095  013  L 

P007  015  s 

A080  005 

S 

A08l  Oil  L 

POll*  Oil  S 

A081*  013  L 

A08.1  014 

L 

A08l  013  L 

AO88  012  L 

A062  016  L 

P011  008 

L 

poii*  007  S 

AO89  012  L 

P007  015  s 

A080  ooi* 

S 

AO88  Oil  L 

A090  012  L 

AO86  008  L 

82 


A063  oo8 

L 

P008  007  S 

P011  016  S 

A009  Oil*  l 

PO05  007 

S 

AO78  001  L 

A039  008  L 

A090  007   S 

A086  013 

L 

A06k   013  L 

AOl*0  013  L 

AO3I+  009  L 

A063  016 

L 

A079  001  L 

AOll*  009  L 

A035  009  L 

P009  003 

S 

A065  013  L 

P012  007  S 

A009  008  L 

A078  008 

L 

P01**  012  S 

A036  013  L 

A091  005  s 

P006  Oil 

S 

AO88  009  L 

AO38  008  L 

A031  Oil*  L 

A079  Oil 

L 

AO89  009  L 

A016  012  L 

A033  Oil*  L 

P007  Oil 

S 

A090  009  L 

P012  003  S 

A012  Oil  L 

A06k   009 

L 

A091  009  L 

A036  008  L 

A012  Oil*  L 

P006  007 

S 

A092  009  L 

AO38  013  L 

A091  007  S 

A065  009 

L 

A093  009  L 

A016  009  L 

A031  009  L 

P007  003 

S 

AO9I*  009  L 

P0.12  015  S 

A033  009  L 

A062  Oil 

L 

A095  009  L 

A029  013  L 

A012  008  L 

P008  003 

S 

P012  015  S 

A030  008  L 

A092  005  S 

A088  008 

L 

A0l*l*  013  L 

A019  012  L 

A039  Oil*  l 

A078  016 

L 

AOij-5  008  L 

P011  015   S 

AOl*0  Oil*  L 

P005  Oil 

S 

AOOl*  012  L 

A029  008  L 

AOll*  Oil  L 

A089  008 

L 

P011  Oil  S 

A030  013  L 

AOll*  Oil*  L 

A079  016 
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013  L 

AO9U 

012  L 

A019  01U 

L 

A072  016  L 

A083  013  L 

AO96 

002  S 

AO78  007 

S 

P011  015  s 

A089  009  S 

A013 

013  L 

A020  012 

L 

A073  OlU  L 

A08U 

013  L 

P007 

010  S 

A079  007 

S 

P011  012  S 

AO85  013  L 

A097 

016  L 

A020  OlU 

L 

AO7U  OlU  L 

AO86 

013  L 

A097 

OlU  S 

A080  007 

S 

POIO  012  S 

AO87  013  L 

AO96  014  L 

A029  012 

L 

A011  016  L 

POlU  00U  S 

A096  008  S 

A08l  007 

S 

P011  006  S 

AO89 

Oil  L 

A075 

Oil  L 

A029  OlU 

L 

A012  016  L 

POIO 

OlU  S 

P007 

016  S 

A082  007 

S 

P013  008  S 

AO66 

Oil  L 

A097 

010  L 

A030  012 

L 

A013  016  L 

P011 

007   S 

A097 

012  S 

AO83  007 

S 

P011  008  S 

AO67 

Oil  L 

AO96 

012  L 

A030  Oll+ 

L 

A075  016  L 

P011 

016  S 

AO98 

002  S 

A08U  007 

S 

P012  008  S 

AO68 

Oil  L 

A076 

Oil  L 

A021  012 

L 

AO76  016  L 

P015 

003  s 

P008  004  S 

A085  007 

S 

P013  Oil  S 

A069 

0.11  L 

A099 

016  L 

A021  OlU 

L 

A077  016  1 

P011 

015  s 

A099 

oiU  s 

AO86  007 

S 

P013  012  S 

A070 

012  L 

AO98 

OlU  L 

A022  012 

L 

AO78  016  L 

P011 

002  S 

AO98  008  S 

AO87  007 

S 

POlU  016  S 

A071 

Oil  L 

A077 

Oil  L 

A022  OlU 

L 

A079  016  L 

A090 

008  S 

P009 

002  S 

P012  007 

S 

P013  007  S 

A072 

Oil  L 

AO99 

010  L 

AO88  016 

L 

A080  016  L 

P007 

00U  S 

A099 

012  S 

POIO  008 

S 

P013  00U  S 

A091 

010  L 

AO98 

012  L 

A009  016 

L 

A08l  016  L 

A091 

012  S 

A100 

002  S 

102 


A078 
poo8 

A101 
A101 
A100 
A100 
A079 
P008 
A101 
A101 
A100 
P013 
A080 
P012 
A08l 
POlU 
A082 
P013 
AO83 
P013 
A08U 
P013 
A085 
P012 
A086 
P012 
AO87 
AO89 
A008 
AO89 
AO67 
A068 
AO69 
A070 
A071 
A072 

A073 
A07U 
A089 
A011 
A012 
A013 
A075 
AO76 
A077 
AO78 
A079 
P0l4 
AO66 
AO89 


Oil 
006 
016 
Ol4 

01U 

008 

Oil 

016 

010 
012 
012 
008 
012 
015 
012 

007 

Oil 

016 

012 

012 

012 

007 

012  L 

Oil  S 

012 

012 

012 

004 

001  L 

001  S 

012 

012 

012 

Oil 

012 

012 

012 

012 

002 

Oll+ 

012 

OlU 

012 

012 

012 

012 

012 

003 

012 


013  L 


A008 
A080 
A08l 
A082 
AO83 
A08U 
AO85 
AO86 
AO87 
POlU 
A008 

A039 
P0l4 
A04l 
P011 
AOUl 
P011 
A043 
P0l4 
A0U3 
POlU 
AOi+5 
POlU 
A0U5 
POlU 
AOk-J 
P015 
AOU7 

P015 
AOi+9 
P015 
AOU9 

P015 
A051 
P015 
A051 
P015 
A053 
POlU 

A053 
POlU 

A055 
poiU 
A055 
P015 
A057 
P015 
A057 
P015 
A059 


004  s 
Oil  L 
Oil  L 
012  L 
Oil  L 
Oil  L 
Oil  L 
Oil  L 
Oil  L 
012  S 
013 
00*+ 

015 
005 
003 
00U 
oo4 
005 

Oil 
00*+ 
012 

005 
008 
oo4 
007 

005 

007 

004 

007  L 

005  S 
012 
004 
015 
005 
Oil  L 

004  s 

008  L 

005  S 

015  L 

oo4  s 

016  L 
005  S 
Oil 
004 
004 
005 
008 

oo4 

Oil 

005 


L 
S 
L 
S 
L 
S 
L 
S 
L 
S 
L 
S 
L 
S 
L 
S 
L 
S 


P015 
A059 
P015 
A088 
A009 
A010 
A011 
A012 
A013 
A0l4 
AOlU 
P012 
AO88 
P015 
A008 
A008 

A007 

A102 
A009 
A06l 
A010 
A062 
A063 
A064 
A065 
AO66 
A102 
A067 
AO68 
A069 
A070 
A071 
A072 
A073 
A07U 
A102 
A011 
A012 
A013 
A075 
AO76 
A077 
AO78 

A079 
A102 
AO80 
A08l 
A082 
AO83 


016 

oo4 

012 
004 
012 
012 
012 
OlU 


008  L 


008  L 
OlU  L 
Oil  S 
013  L 
016  S 

008  L 

005  s 

001  L 

007  s 

009 
009 
009 
009 
009 
Oil  L 

009  L 
009 
008 
009 
009 
009 
009 
001 
009 
009 
009 
009 
009 
009 
012 
009 
009 
009 
009 
009 
001 
009 


009  L 

009  L 
009  L 


AOQk   009  L 


AO85 

AO86 

AO87 

P012 

A088 

AO88 

A102 

A102 

A103 

A009 

P007 

A104 

A101+ 

A103 

A103 

A06l 

P007 

AlOk 

A104 

A103 

A105 

A010 

P007 

A106 

A106 

A105 

A105 

A062 

P007 

A106 

A106 

A105 

A107 

AO63 

P007 

A108 

A108 

A107 

A107 

A064 

P007 

A108 

A108 

A107 

A109 

A065 

P007 

A110 

A110 

A109 


009  L 
009  L 
009  L 

015  S 

009  L 
008  S 
Oil  L 
013  L 
002  S 
008  L 
006  S 
016 
Ol4 
(XLk 
008 
008 
008 

010  L 
012  S 
012 
002 
008 
004 
016 
01k 
OlU  L 
008  S 
008  L 
010 
010 
012 
012 


002 
008  L 
Ol4  S 
016  L 
Ol4  S 
Ol4  L 
008  S 
012  L 
016  S 
010  L 
012  S 
012  L 
002  S 
008  L 
012  S 
016  L 
Ol4  S 

014  L 
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A109  oo8 

S 

P008 

Oil* 

s 

A126  012 

S 

AOll*  005  S 

A066  008 

L 

A118 

010 

L 

A125  012 

L 

A077  013  L 

P008  002 

S 

A118 

012 

S 

A127  002 

S 

AOll*  OOl*  S 

A110  010 

L 

A117 

012 

L 

A080  008 

L 

A079  013  L 

A110  012 

S 

A119 

002 

S 

POOS  Oil* 

S 

P012  016  S 

A109  012 

L 

A011 

008 

L 

A128  016 

L 

AO88  012  L 

Alll  002 

S 

P009 

006 

S 

A128  Oil* 

S 

A088  005  s 

AO67  008 

L 

A120 

016 

L 

A127  Oil* 

L 

M35  Oil  L 

P008  006 

S 

A120 

Oil* 

S 

M27  008 

S 

M35  013  L 

A112  016 

L 

AII9 

Oil* 

L 

A08l  008 

L 

M35  007  S 

A112  Oil* 

S 

AII9 

008 

S 

P009  002 

S 

A009  001  L 

Alll  Oil* 

L 

A012 

008 

L 

A128  010 

L 

A06l  001  L 

Alll  008 

S 

P009 

012 

S 

A128  012 

S 

A010  001  L 

A068  008 

L 

M20 

010 

L 

M27  012 

L 

A062  001  L 

P008  008 

S 

M20 

012 

S 

A129  002 

S 

A063  001  L 

A112  010 

L 

AII9 

012 

L 

A082  008 

L 

A061*  008  L 

A112  012 

S 

A121 

002 

S 

P009  006 

S 

A065  001  L 

Alll  012 

L 

A013 

Oil 

L 

A130  016 

L 

AO66  001  L 

A113  002 

S 

P009 

008 

S 

A130  Oil* 

S 

M35  008  S 

AO69  008 

L 

M22  016 

L 

M29  Oil* 

L 

AO67  001  L 

P008  OOl* 

S 

A122 

Oil* 

S 

M29  008 

S 

AO68  001  L 

Allk   016 

L 

A121 

01U 

L 

A083  008 

L 

AO69  001  L 

Allk   Oil* 

S 

A121 

008 

S 

P009  008 

S 

A070  001  L 

A113  oil* 

L 

A075 

008 

L 

A130  010 

L 

A071  008  L 

A113  008 

S 

P009 

00l+ 

S 

A130  012 

S 

A072  001  L 

A070  008 

L 

A122 

010 

L 

A129  012 

L 

A073  013  L 

P008  012 

S 

A122 

012 

S 

A131  002 

S 

A07l*  013  L 

Allk   010 

L 

A121 

012 

L 

A081*  008 

L 

A135  009  S 

Allli  012 

S 

A123 

002 

S 

P009  012 

S 

AOll  001  L 

A113  012 

L 

AO76  008 

L 

A132  016 

L 

A012  001  L 

A115  002 

S 

P009 

Oll+ 

S 

A132  Oil* 

S 

A013  001  L 

A071  016 

L 

A124  016 

L 

A131  Oil* 

L 

A075  001  L 

P008  002 

S 

M2U  Oll+ 

S 

A131  008 

S 

A076  001  L 

Ml6  016 

L 

M23 

Oil* 

L 

A085  008 

L 

A077  001  L 

A116  Ol4 

S 

A123 

008 

S 

P009  Oil* 

S 

A078  001  L 

A115  Ollf 

L 

A077 

008 

L 

M32  010 

L 

A079  001  L 

A115  008 

S 

P009 

016 

S 

M32  012 

S 

A135  001  S 

A072  008 

L 

M2*+ 

010 

L 

A131  012 

L 

A080  001  L 

P009  ooi* 

S 

A121+ 

012 

S 

A133  002 

S 

A08l  001  L 

Ml6  010 

L 

M23 

012 

L 

AO86  008 

L 

A082  001  L 

A116  012 

S 

A125 

002 

S 

P009  010 

S 

AO83  001  L 

A115  012 

L 

AO78  008 

L 

AI3I+  016 

L 

A081*  001  L 

M17  002 

S 

P009 

010 

S 

A131*  Oil* 

S 

AO85  001  L 

A073  008 

L 

M26 

016 

L 

A133  oil* 

L 

A086  001  L 

P008  012 

S 

A126  Oil* 

S 

A133  008 

S 

AO87  001  L 

A118  016 

L 

A125 

Oil* 

L 

A087  008 

L 

A118  Oil* 

S 

A125 

008 

S 

P009  016 

S 

M17  Oll+ 

L 

A079 

008 

L 

A13U  010 

L 

A117  008 

S 

POOS 

016 

S 

M3I*  012 

S 

A07I+  008 

L 

M26 

010 

L 

A133  012 

L 

10*1 


APPENDIX  B 

P-fGIN 
% 

%  THt  pHAvjsjEL  RDJTIN3  pRDGRAm  *<HlCH  FDLLOwS  WAS  DEvELTPEO  AT  THE 

It  UNIVERSITY  DF  ILLINOIS  5 Y  jTM  STEVENS.   THE  DESIGN  DF  THIS  'RD- 

I  r,RAvi  TS  THE  SJgjEcT  Tr  ChAoTER  rl  v/E  f)r  THE  »hD  THESIS  ENTITLED 

*  uJERlSTTe  TfCH^EpJiS  FD'  Hr  AjTOvATED  ?  E  S I  r,  VJ  Or  PRINTED  CIRCUIT 

*  PDAPDS.   RRTE^LY  T"1-  AlGDRITH*  'RDCEEDS  BY  DIVIDING  E*CH  C  DNNr  p  T I  ON 
K  TMTH  THPrE  wlRE  SEGMENTS,  T  ^D  HORIZONTAL  AMD  ONE  VERTTfAL.  THESE 

1!  WIRE  SEGMENTS  ARE  THEN  ASSIGNED  TO  S  p  A  C  '  S  ON  THE  STAR"  WHICH  ARE 

*  TMPLC^E MTED  AS  TwD  Arrays,  v/ERT<  TOR  VERTICAL  WTRES  Amd  HDR3  TOR 

%  4-IPT7TJTAI.  WIRES.   THE  PRIBRAM  ASSUHFS  THAT  THE  BOARD  TS  COMPOSED 

%  Tr  E  L  r  V  E  •>•  R  D  w  S  OF  "TETEEV  If  a  I M  DI|_  IC  PACKAGES.   T  H  r  SPACING 

t  9"TwEf"N  3DwS  ANJD  CD'.  JMVS  Or  ?AC<*GES  TS  DEPENDANT  DM  THE  VARIABLES 

I  \/s  Av^  H*.   FINAJ.  POSITIONS  J"  THE  WIRE  SEGMENTS  IS  DrTER^lNED  3Y 

j!  THE  Z  *  A  N  v  E  L  ASSIGNMENT  A  L  d  3  R I  T  H  vi , 

I! 

*  rACH  HDRT7DNTA,  WIRE  S^G*Ev)T  IS  REPRESENTED  As  ONE  A7  ?IT 
t  wDRD  WITH  THE  EDLLLDwINS  rIrlDS,   VERTICAL  *IRE  SEGMENTS  ARE 

t  REPRESENTED  wITH  THE  SA*E  TYPE  DF  WORD  ONLY  THE  END  POINTS  ARE 

*  CALLED  Tls  AMD  9DTTDM, 

I! 

%  PITS  USAGE 

% 

t  0  TD  S         OTFSET  DF  RTSHT  E^D  POINT  WITHIN  SPACE 

%  *,    TD  10        VERTICAL.  SPACE  DF  RIGHT  END  P^INT 

1!  11  T3  IS       OUTSET  D?  L^rT  ^0  °OlNT  -ITH^N  SPACE 

I  \7    TD  21       VERTICAL  S'ASE  DE  Lff"T  END  P&INT 

%  ??    TD  30       PDINTER  TD  VERTICAL  WIRE  sEgmEnT  CONNECTED  TD  ThE 

«  RIGHT  END  Dr  THTS  "IRE  5EGMENT 

f  31  T3  30       PDINTER  TD  VERTICAL  WIRE  SEGMENT  CONNECTED  TO  THE 

*  LEET  END  Df  THIS  *IRE  SEGMENT 
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«9  TAG  TO  InDKATE  FT*«L  POSITIONING  Or  THIS  WIRE  SES 

01  to  n*    njwrer  jr   j-ir  channel  his  wire  segmemt  ts  assigned 


FILE    B!>IMT    15(2*17)1 

tile  carts   r?»tO)i 

F  1 1* r    W  I  R  '„  I  5  T    0  T  S  <    S  E  }  T  «  I    »RRRRR»/»WlRLl$T"    (2*10*30)1 

T M T F G E *    RTT,|.FT,T0o»:>0T.RTT;)rF,T3J,TR?»i:>>3ir,,IN0,3I',,:s, 

LrTTrr,Tl»-)rr,3]rTrr,I»J»RpTR, 
J1»J?,HS,HSH,V>,VSH,3TR,SPAC  , 
Tl,IP,V°H,H'H#V3»H:'.c'I:?ST»Lfl5T,o?EuSC",[)u^9, 

CHANNEL, ?EST.RLl"»3J,<,RLlw»IT»JJ*SPEC* 
LpTR,T'TR,^3TR,TEM9| 
T M T E 3 E R    rTRST3,LftSTP»RT.LT»RTDrr,l„T0rr»RTPTR,LTPTR| 
tiom       ?9RAy    4nRSr0jll,3!?35]»HSPTR[OiJ11, 

tf£*TS[0lia»0t255)»VSaT?t9l15]l 
Mom       rt?9AY    ^3"BrO«?3,0«'5S],H3PTRrOl23]» 
V=-RT:>r0riq,0:?53',»tf:>3TR(0tl4]l 
TiR^AT       ruT(ai3),CHE'<()(?»;:,I5/'>,Mr^(X2»lSl5), 

wrv^T(?i9),r  RFXT(»sOTnTER    ERROR"»0       »"">DES    NOT    PHTNT    TO", 15), 
C  H  r  M  T  f  I  * ,  "         MAvjNrtS    J  $  E  0    IN    S°ACE       » ,  I  5  /  )  J 
L*3EL    NExTV#NExTH#ERR3R»E3JTl 
LA3EL      ETr^MOREl 
I.AREL       *TTE»RITOj 
LAREL       ERR0R1) 
alpha    TILNAmEI 
FORMAT    :AROrMT(AS)J 

REftO(CAR0<;»CAR0FMT,FlLNA«E); 
FTLL     WTRLT5T     WITH  r I ^N A  WE  J »R - [ 0 H 5 » 6 ) t 

WRITE(dRTnT,CAROFMT#cT^\jAmE)| 
VSHt=(VSt s9)     OIV     21 
VDHtx(v°l=7)    DIV    2    I 
HSHltf-ISJe?    )    DIV    ?l 


io6 


PET  A  r>    rpOM     WMELIST.     :]l^    EMRTTES     rOR    C^CH    C3^rCTnN,        FIRST 
r,TVrS    Tmf    COO^OT  vj  a  T  =■  s    Df    Th*"    9  0  *'    Asjo    COLUMN    OF    ONE    ?Ar<AQE    TO    BE 
CONMETTEn    AT       THE    °TN    53ECIPIE0    BY    FMSTP.     'UAST    GIVES    T-lF    »OSTTIOM 
IF    Tnr.     OT-IEP    3AC<»3r    TO    3?    CO^NECTEO    AT    PIM    L4STp.       Eor,r    CO^FCfr)R 
PIM5     OF     THE     30AR0     A^PEA?     A5     PARAGES     IN    ROW    7ERO. 


WORE!       PEATfWT;?LTST,rviTf-TR5T,rnSTp,LaST,LA^Tp)rE0Fij 
V  *  P  T  P  r  1  5  ]  t  r  ?  5  5  I 
TPt  tBT1?l  =0J 
11  :  ■rTRST«C7l«]l 
jl ; =  rUSTtr  3:a] » 
!P:=LA^T.[7jO]| 
J  P  t  =  i_  A  s  T  .  r  3  14  1 J 
TF    J1=J?    THr?j 


ottm    oft  r  i/ a  r;c-  <;    j\j    0  v  p    c  "I  L  J  vi  m  . 

IF    »/S«»TRt  Jl  ♦  J  1    LSS    i/S'T^Jl]    THEM. 
BEGIM 
jS=?TJ=PITJ=Jlfl> 
LT:=lET:=j|| 
pTPTRtrRPTPt  =\Z^°T7[J31 
LTOTRlstPT^t  r51 1 ) 
pTTOFF«=PTnrF»  =\/5H| 
TF    i.A5T«>    STP    9    THEM    BEGIN 

'..FTOEFlcVS  +  l  7-LAST0; 
TB2»rl> 

FMO    ELSE 
LFTO^JrVSHAST9! 

IF    FIRSTP    GTP       9     T^rsj    9rGIN. 

LTDFFl«VS«     ir-FTRSTP| 

TBI  l«U 
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* 
* 

t 

* 
* 
t 
t 
% 


END  ELSE 
LTTFE  irVS  +  HSST"! 

r^o  ELSE 
3T6IM 

Jl rPTts^ITI sJl| 

LTtsLTTtrJl  I 

PT°Tf»ir9DT9J=5in 
LTpT*,=L=>TO.  »rVS?T9[  J  ]  J 

LTTrrts^rTDFrtsV'SHl 
IF    |,ASTP    GTR    3    THEM    3  T  r.  I N 
9TTnrft-vs+l6-L»ST3| 

eni  else 
?TTnrr:=\/s  +  LASTB-i  i 
if   n^ST3  r,T9  q   men   ^ ?: s i m 

Til  t  =  l  J 

eni  else 

^nrr:=W5  +  FiRsTB-l| 
END> 

Tf  Jl  GT9  J2  THEN 

pENE^*L  C3^MECTIDN 
«ESlN 

THE    VERTICAL    (C:    SEG^NT    F0*    EACH    CONNECTION    IS    ASSISTED 
TO    TH*"    Vr^TTC*L    S»ACE    «HT*H    HAS    THE    FEWEST     «TRE    SEGMENTS    AL^EAQy 
ASSTSNEO    TD    IT    AND    LIES    HEUEEN    THE    COLJ^S    Of    THE    Trfn    t»AC<AGES 
<*EING    CONNECTED, 


«TG«s?55; 
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EOR  IMDib  J?«-t  STro  1  JNTIL  Jl  DO 

If  VSPTRflNO]  LSS  ^  I S  THEN  REGTN 

RTGPt sIND» 
ENOJ 
Jt «^ I t i =BIGPI 
LF"Ttsj2; 
RTT3"Et=VSHJ 
ir  LAST=>>&  THEN  RE3lN 

im^f  J=VS  +  17-LASTP» 
T^  2  I =  1  | 
EN3  ELSE 

LFnFri=VS*LASTB) 
RPTRt=VSPTR[  JIJ 
L°TRis511  » 
RTl=,|l  I 
LTlsJI 
ir  rlRST3^  THEN  3£SI«J 

STOFFlaVS*]  6-rMST?» 

tri  1=11 

E'O  ELSE 

9  t  d  r  r  j  s  y/ s  f  E  n  S  T  3  -  u 
LTnrrirv/s-U 

LTPT9»sV/SBTRf  J]  t 
RTPTRteSllJ 
END* 
If  Jl  LSS  J2  THEN 
PEGl^ 

THE  VERTICAL  WT*£  SEGMENT  rQR  EACH  CONNECTION  IS  ASSIGNED 
TO  TAf    VERTICAL  SPACE  WHKH  HAS  THE  FEWEST  WIRE  SEGMENTS  ALREADY 
ASSIGNED  TD  IT  Avn  Ll^S  RETWEEN  THE  COLONS  OE  THE  TWn  PACKAGES 
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